對於這個問題,我的處理方法是:
1.先通過遞歸數出字符串中連續空格的個數。
2.將有連續空格的位置去除多余空格。
3.判斷首尾是否有空格。
第一步,判斷當前位置是否是空格以及連續空格的個數,這裡使用一個遞歸的方法比較簡單。代碼如下:
public static int getBlankNumber(String s, int index) { if (index < s.length()) { if (s.charAt(index) == ' ') { return getBlankNumber(s, index + 1) + 1; } else { return 0; } } else { return 0; } }
傳入字符串對象 s ,以及當前的位置 index,最終返回一個 int 型的結果,也就是多少個空格。
第二步,跟上返回的空格數,與當前的位置,使用 String 對象自帶的 substring() 方法,將字符串分割為兩部分,去掉中間的空格,再連接起來,使連續多個空格變為一個。代碼如下:
public static String mergeBlank(String s) { int numberBlank = 0; String a1; //字符串的第一部分 String a2; //字符串的第二部分 for (int index = 0; index < s.length(); index++) { //循環整個字符串,判斷是否有連續空格 numberBlank = getBlankNumber(s, index); if (numberBlank >= 2) { //根據連續空格的個數以及當前的位置,截取字符串 a1 = s.substring(0, index); a2 = s.substring(index + numberBlank - 1, s.length()); s = a1 + a2; //合並字符串 } } return s; }
第三步,第二步完成之後,第三步就很簡單了,因為我們已經將字符串中多余的空格變為一個空格,如果需要去除首尾空格,只需要判斷首尾是否是空格即可。代碼如下:
public static String trim(String s) { if (s.charAt(0) == ' ') { s = s.substring(1, s.length()); } if (s.charAt(s.length() - 1) == ' ') { s = s.substring(0, s.length() - 1); } return s; }
這樣一來,一個去除多余空格,去除首尾空格的函數就完成了。接下來調用一下看看,代碼如下:
public static void main(String[] args) { String name = mergeBlank(" aaa a aa "); System.out.println("name="+name+"|"); //結果:name= aaa a aa | name = trim(name); System.out.println("name="+name+"|"); //結果:name=aaa a aa| }