题解 | #替换空格#

替换空格

http://www.nowcoder.com/practice/0e26e5551f2b489b9f58bc83aa4b6c68

替换空格


描述

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

数据范围:0 ≤ len(s) ≤ 1000 。 保证字符串中的字符为大写英文字母、小写英文字母和空格中的一种。

示例:

输入:"We Are Happy"
返回值:"We%20Are%20Happy"

示例:

输入:" "
返回值:"%20"

解法一:

public static String replaceSpace(String s) {
        
        String a = "";
        //  1、把输入的字符串转换为字符数组
        char[] chars = s.toCharArray();
        // 2、遍历数组
        for (char aChar : chars) {
            // 3、把char转为String
            String str = String.valueOf(aChar);
            // 4、判断是否是空格
            if (str.equals(" ")) {
                // 5、是空格,替换为%20
                a += "%20";

            } else {
                a += str;

            }
        }
        return a;
    }

复杂度分析:

  • 时间复杂度:O(n),所有字符都遍历一遍
  • 空间复杂度:O(n),用到了数组存储

解法二:使用StringBuilder

  • 把字符串中的每个字符一个个添加到StringBuilder中,如果遇到空格就把他换成%20。
     public static String replaceSpace(String s) {
        // 1、定义一个字符缓冲区stringBuilder
        StringBuilder stringBuilder = new StringBuilder();
        // 2、遍历字符串
        for (int i = 0; i < s.length(); i++) {
            // 3、charAt() 方法用于返回指定索引处的字符
            if (s.charAt(i) == ' ')
                // 4、为空格,返回%20
                stringBuilder.append("%20");
            else
                stringBuilder.append(s.charAt(i));
        }
        return stringBuilder.toString();
    }

复杂度分析:

  • 时间复杂度:O(n),所有字符都遍历一遍
  • 空间复杂度:O(n),StringBuilder需要的空间
全部评论

相关推荐

06-04 18:37
门头沟学院 Java
勇敢的ssr求对象:前面看的有点奔溃,看到只有你是真玩啊,忍不住笑出了声😂
点赞 评论 收藏
分享
AAA不喝拿铁:西电本硕学历没问题,但是项目名字首先得改虽然一眼能看出来是点评但是不能演都不演就直接给面试官端上去。技术点全是redis显得这像redis的课程实验,也要改。我根据真实面经整理得到的最全(高/中/低频)面试题,需要的牛u可以订阅一手我的专栏,祝好运
点赞 评论 收藏
分享
mjasjon:这种trash中厂 简历过筛概率比大厂还低(除阿里系)
投递哔哩哔哩等公司6个岗位
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务