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();
    }
}
目录
相关文章
|
6天前
|
Java C++ Python
剑指 Offer 05:替换空格
剑指 Offer 05:替换空格
25 0
|
C++ 容器
剑指 Offer 58 - II. 左旋转字符串(3种方法)
字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。 请定义一个函数实现字符串左旋转操作的功能。 比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。
47 0
|
存储
图解LeetCode——剑指 Offer 50. 第一个只出现一次的字符
图解LeetCode——剑指 Offer 50. 第一个只出现一次的字符
56 0
图解LeetCode——剑指 Offer 57. 和为s的两个数字
图解LeetCode——剑指 Offer 57. 和为s的两个数字
49 1
|
算法
LeetCode:剑指 Offer 58 - II. 左旋转字符串
题目描述:字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。
|
Python
LeetCode 剑指 Offer II 004. 只出现一次的数字
给你一个整数数组 nums ,除某个元素仅出现 一次 外,其余每个元素都恰出现 三次 。
64 0
LeetCode 剑指 Offer 05. 替换空格
请实现一个函数,把字符串 s 中的每个空格替换成"%20"。
61 0
LeetCode 剑指 Offer 58 - II. 左旋转字符串
字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。
66 0
AC 剑指 Offer 07. 重建二叉树
AC 剑指 Offer 07. 重建二叉树
64 0