替换空格

2年前 (2022) 程序员胖胖胖虎阿
338 0 0

请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy

解法一:直接调用函数

这种做法面试官看了直呼内行,然后反手把你挂了

public class Solution {
    public String replaceSpace(StringBuffer str) {
     return str.toString().replaceAll(" " , "%20");
    }
}

解法二:

构造一个新的字符串,遍历原字符串,把字符依次挪到新字符串,遇到空格就换成题目要求的新字符

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

解法三:

从前向后记录空格的数目,从后向前替换空格

0 1 2 3 4 5 6 7 8 9 10 11
w e   a r e   l u c  k  y

假设空格的个数为 count,可以得知 count 为 2,所以在替换的时候,下标 7 ~ 11 的字母要向后移动 count × 2 个位置,3 ~ 5 字母要向后移动 (count - 1) × 2 个位置。 所以得到 :

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
w e   a r e   l u c  k y 
w e       a r e        l   u  c  k  y

这时就可以直接在空格处写入 %20 了

public class Solution {
    public String replaceSpace(StringBuffer str) {
        // 计算空格数
        int spaceCount = 0;
        for(int i = 0; i < str.length(); i++) {
            if (str.charAt(i) == ' ') {
                spaceCount++;
            }
        }
        // 保存下标
        int index = str.length() - 1;
        // 扩大长度
        str.setLength(str.length() + spaceCount*2);
        while (index >= 0) {
            if (str.charAt(index) != ' ') {
                str.setCharAt(index + spaceCount * 2, str.charAt(index));
            } else {
                spaceCount--;
                str.setCharAt(index + spaceCount * 2, '%');
                str.setCharAt(index + spaceCount * 2 + 1, '2');
                str.setCharAt(index + spaceCount * 2 + 2, '0');
            }
            index--;
        }
        return str.toString();
    }
}

总结:字符替换类的题目,要大胆假设,不要觉得想法过于复杂就放弃思考

版权声明:程序员胖胖胖虎阿 发表于 2022年9月22日 上午5:24。
转载请注明:替换空格 | 胖虎的工具箱-编程导航

相关文章

暂无评论

暂无评论...