最近在看Robert Sedgewick 和Kevin Wayne寫的演算法(第四版) ,看到字元串部分,正好給出了Java字元串的API(部分,也是直接自己接觸的較為常用的) 覺得自己也應該好好總結一些,首先給一點簡單的,之後看到第五章部分,有關字元串的內容再補上。 表 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:東西到是沒多少,這個編輯起來好費勁啊.....