408,剑指 Offer-替换空格

想了解更多数据结构以及算法题,可以关注微信公众号“数据结构和算法”,每天一题为你精彩解答。也可以扫描下面的二维码关注
在这里插入图片描述

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


示例 1:

输入:s = “We are happy.”

输出:“We%20are%20happy.”


限制:

0 <= s 的长度 <= 10000


先把字符串转换为单个字符

这里让求的是把字符串中的空格替换成%20,其中一种实现方式就是申请一个临时数组,然后再遍历这个字符串的每个字符,如果不是空格就把遍历的字符添加到临时数组中,如果是空格就添加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;
}

使用StringBuilder

还有一种方式和上面差不多,就是把字符串中的每个字符一个个添加到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();
}

如果还想要更简单的,直接调用API,一行代码搞定

public String replaceSpace(String s) {
    return s.replace(" ", "%20");
}

总结

这题应该是非常简单的一道题了,没什么好说的。


在这里插入图片描述

posted @ 2020-09-21 22:46  数据结构和算法  阅读(71)  评论(0编辑  收藏  举报