Java 的字符串API(部分)及字符串处理

最近在看Robert Sedgewick 和Kevin Wayne写的算法(第四版) ,看到字符串部分,正好给出了Java字符串的API(部分,也是直接自己接触的较为常用的)

觉得自己也应该好好总结一些,首先给一点简单的,之后看到第五章部分,有关字符串的内容再补上。

表 Java 字符串API(部分)

Public class String

 

String()

创建一个空字符串

int

length()

字符串长度

int

charAt(int i)

第i个字符

int

indexOf(String p)

p第一次出现的位置(无则 -1)

int

indexOf(String p,int i)

p在i个字符后第一次出现的位置(无则-1)

String

concat(String t)

将t附在字符串末尾

String

substring(int i,int j)

该字符串的子字符串(从第i个到j-1个)

String[]

split(String delim)

使用delim分隔符切割字符串

int

compareTo(String t)

比较字符串

Boolean

equals(String t)

该字符串的值和t的值是否相同

int

hashCode

散列值

 

字符串操作举例

1 String a = "now is ";
2 String b = "the time ";
3 String c = "to";
方法  返回值
a.length()  7
a.charAt(4)  i
a.concat(c)  "now is to"
a.indexOf("is")  4
a.substring(2,5)  "w i"
a.split(" ")[0]  "now"
a.split(" ")[1]  "is"
b.equals(c)  false

 

 

 

 

 

 

 

 

其中 “+” 运算符是可以代替concat()方法的。

还有一些高级的用法,比如 split()方法 的参数可以是 正则表达式 

典型的字符串处理代码中split()的参数是“\\s+”  表示“一个或多个制表符、空格、换行符或回车”

 

典型字符串处理代码如下:

任务一:判断字符串是否是一条回文

1 public static boolean isPalindrome(String s){
2         int N = s.length();
3         for (int i = 0; i < N / 2; i++) {
4             if (s.charAt(i) != s.charAt(N-1-i))
5                 return false;
6         }
7         return true;
8     }

任务二:从一个命令行参数中提取文件名和扩展名

1 String s = args[0];
2 int dot = s.indexOf(".");
3 String base = s.substring(0,dot);
4 String extension = s.substring(dot+1,s.length());

任务三:打印出标准输入中所有含有通过命令行指定的字符串的行

1 String query = args[0];
2 while (!StdIn.isEmpty()){
3   String s = StdIn.readLine();
4    if(s.contains(query)) StdOut.println(s);
5 }

任务四:以空白字符为分隔符从StdIn中创建一个字符串数组

1 String input = StdIn.readAll();
2 String[] words = input.split("\\s+");

任务五:检查一个字符串数组中的元素是否已按照字母表顺序排序

1 public boolean isSorted(String[] a){
2         for (int i = 1 ; i < a.length() ; i++) {
3             if (a[i-1].compareTo(a[i]) > 0)
4                 return false;
5         }
6         return true;
7     }

 

 

 

ps:东西到是没多少,这个编辑起来好费劲啊.....

 

 

 

 

 

猜你喜欢

转载自www.cnblogs.com/mereder/p/9291723.html