AC 剑指 Offer 05. 替换空格

简介: AC 剑指 Offer 05. 替换空格

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

示例 1:

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

限制:

0 <= s 的长度 <= 10000

class Solution {
    /**
     * @Title: replaceSpace
     * @Description: 使用replaceAll函数,但是replaceAll里面其实使用了StringBuffer
     * @author: itbird
     * @date 2022年3月15日 下午3:08:37
     * @param s
     * @return String
     * 时间复杂度: O(N)
     * 空间复杂度: O(N)
     */
    public String replaceSpace(String s) {
        return s.replaceAll("\\s", "%20");
    }
    
    /**
     * @Title: replaceSpace
     * @Description: 遍历字符串数组,进行替换
     * @author: itbird
     * @date 2022年3月15日 下午3:08:37
     * @param s
     * @return String
     * 时间复杂度: O(N)
     * 空间复杂度: O(N)
     */
    public String replaceSpace1(String s) {
        //把字符串 s 中的每个空格替换成"%20"
        StringBuilder builder = new StringBuilder();
        for (int i = 0; i < s.length(); i++) {
            if (s.charAt(i) == ' ') {
                builder.append("%20");
            } else {
                builder.append(s.charAt(i));
            }
        }
        return builder.toString();
    }
}
目录
相关文章
|
8月前
|
Java C++ Python
剑指 Offer 05:替换空格
剑指 Offer 05:替换空格
47 0
|
4月前
|
C语言 C++
剑指 Offer(第 2 版)刷题 | 05. 替换空格
本文是作者在刷《剑指 Offer(第 2 版)》时对 "替换空格" 问题的解法分享,包括正确处理字符串中空格替换为"%20"的解法以及未刷题小白可能会犯的错误,同时记录了在解决过程中遇到的运行时错误。
剑指 Offer(第 2 版)刷题 | 05. 替换空格
|
8月前
剑指 Offer 50:第一个只出现一次的字符
剑指 Offer 50:第一个只出现一次的字符
40 0
|
8月前
|
Java C++ Python
剑指 Offer 58 - II:左旋转字符串
剑指 Offer 58 - II:左旋转字符串
71 0
|
C++ 容器
剑指 Offer 58 - II. 左旋转字符串(3种方法)
字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。 请定义一个函数实现字符串左旋转操作的功能。 比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。
72 0
|
算法
LeetCode:剑指 Offer 58 - II. 左旋转字符串
题目描述:字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。
LeetCode 剑指 Offer 58 - II. 左旋转字符串
字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。
89 0