0
点赞
收藏
分享

微信扫一扫

剑指Offer面试题5:替换空格

一、题目

请实现一个函数,把字符串中的每个空格替换成“%20”。例如:输入“We are happy.",则输出”We%20are%20happy."。

二、解析

2.1 解法一

申请一个临时数组,然后再遍历这个字符串的每个字符,如果不是空格就把遍历的字符添加到临时数组中,如果是空格就添加3个符'%','2','0'分别到临时数组中,最后再把临时数组转化为字符串即可。

    public String replaceSpace(String s) {
        int length = s.length();
        char[] array = new char[length * 3];
        int index = 0;
        for (int i = 0; i < length; i++) {
            char c = s.charAt(i);
            if (c == ' ') {
                array[index++] = '%';
                array[index++] = '2';
                array[index++] = '0';
            } else {
                array[index++] = c;
            }
        }
        String newStr = new String(array, 0, index);
        return newStr;
    }

2.2 解法二

把字符串中的每个字符一个个添加到StringBuilder中,如果遇到空格就把他换成%20。

    public String replaceSpace(String s) {
        StringBuilder stringBuilder = new StringBuilder();
        for (int i = 0; i < s.length(); i++) {
            if (s.charAt(i) == ' ')
                stringBuilder.append("%20");
            else
                stringBuilder.append(s.charAt(i));
        }
        return stringBuilder.toString();
    }

举报

相关推荐

0 条评论