思路:若在同一个字符串移动,先遍历出空格个数,开辟空间,再从后往前遍历和复制。若允许新的空间,可随意。

 solution1:

    public class Solution {
    public String replaceSpace(StringBuffer str) {
        if(str == null || str.length() == 0){
            return str.toString();
        }
        StringBuffer str1 = new StringBuffer();
        for(int i = 0; i < str.length(); i++){
            if(str.charAt(i) == ' '){
                str1.append("%20");
            } else {
                str1.append(str.charAt(i));
            }
        }
        return str1.toString();
    }
    }

solution2:

    public class Solution {
    public String replaceSpace(StringBuffer str) {
        if(str == null || str.length() == 0){
            return str.toString();
        }
        int oldlen = str.length();
        int blank = 0;
        for(int i = 0; i < str.length(); i++){
            if(str.charAt(i) == ' '){
                blank++;
            }
        }
        int len = str.length() + blank * 2;
        //从后往前遍历str
        str.setLength(len);
         
        int index = len - 1;
        for(int j = oldlen - 1; j >= 0 && index > j; j--){
            if(str.charAt(j) == ' '){      
                str.setCharAt(index--, '0');
                str.setCharAt(index--, '2');
                str.setCharAt(index--, '%');
 
            } else {
                str.setCharAt(index--,str.charAt(j));
 
            }
        }
        return str.toString();
    }
    }

solution3:

    public class Solution {
    public String replaceSpace(StringBuffer str) {
         
        return str.toString().replaceAll("\\s", "%20");
    }
    }
测试用例:
字符串有空格(最前面,最后面,字符串中间,有连续多个字符)
没有空格
输入null,空,只有连续多个空格

posted on 2017-07-01 13:31  Scarlett meng  阅读(1166)  评论(0编辑  收藏  举报