剑指 Offer 05. 替换空格

请实现一个函数,把字符串 s 中的每个空格替换成"%20"。

示例 1:

输入:s = "We are happy."
输出:"We%20are%20happy."

限制:

0 <= s 的长度 <= 10000

 

题解:

    public static void main(String[] args) {
        // TODO Auto-generated method stub

        String s = "We are happy.";
        System.out.println(replaceSpace2(s));
    }

    //方法一:直接用String的replaceAll方法替换
    public static String replaceSpace(String s) {
        return s.replaceAll(" ", "%20");
    }
    //方法二:StringBuilder
    public static String replaceSpace1(String s) {
        StringBuilder sb = new StringBuilder();
        for(char ch:s.toCharArray()){
            if(ch==' '){
                sb.append("%20");
            }else{
                sb.append(ch);
            }
        }
        return sb.toString();
    }
    //方法三:字符数组
    public static String replaceSpace2(String s) {
        char[] result = new char[s.length()*3];
        int i=0;
        for(char ch:s.toCharArray()){
            if(ch==' '){
                result[i++]='%';
                result[i++]='2';
                result[i++]='0';
            }else{
                result[i++]=ch;
            }
        }
        return new String(result,0,i);
    }
}

方法一:
执行用时:3 ms, 在所有 Java 提交中击败了16.03%的用户
内存消耗:36.6 MB, 在所有 Java 提交中击败了8.10%的用户

方法二:
执行用时:0 ms, 在所有 Java 提交中击败了100.00%的用户
内存消耗:36.3 MB, 在所有 Java 提交中击败了60.83%的用户

方法三:
执行用时:0 ms, 在所有 Java 提交中击败了100.00%的用户
内存消耗:36.3 MB, 在所有 Java 提交中击败了54.57%的用户

posted @ 2021-06-22 22:22  Vincent-yuan  阅读(43)  评论(0编辑  收藏  举报