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
|
存储
图解LeetCode——剑指 Offer 50. 第一个只出现一次的字符
图解LeetCode——剑指 Offer 50. 第一个只出现一次的字符
80 0
|
Python
LeetCode 剑指 Offer II 004. 只出现一次的数字
给你一个整数数组 nums ,除某个元素仅出现 一次 外,其余每个元素都恰出现 三次 。
105 0
AC 剑指 Offer 35. 复杂链表的复制
AC 剑指 Offer 35. 复杂链表的复制
106 0
AC 剑指 Offer 35. 复杂链表的复制
AC 剑指 Offer 12. 矩阵中的路径
AC 剑指 Offer 12. 矩阵中的路径
85 0
AC 剑指 Offer 12. 矩阵中的路径
leetcode【剑指 Offer 05. 替换空格—简单】541.替换空格
leetcode【剑指 Offer 05. 替换空格—简单】541.替换空格