染罕习 发表于 2025-6-13 07:57:43

剑指offer-2、替换空格

题目描述

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

调⽤API函数

java ⾥⾯有可以直接使⽤的函数replace() ,直接写成下⾯这样即可通过。
public String replaceSpace(StringBuffer str) {
        String result = str.toString().replace(" ","%20");
        return result;
}使用StringBuilder拼接

使用额外的空间。对字符串进行遍历,然后使用StringBuilder进行字符串的拼接,遇到空格添加%20,没有则直接添加。
public class Solution {
    public String replaceSpace(StringBuffer str) {
      //如果字符串为空的话,直接返回null
      if(str == null) return null;
      StringBuilder sb = new StringBuilder();
      for(int i = 0; i < str.length(); i++){
            if(str.charAt(i) == ' '){
                sb.append("%20");
            }else{
                sb.append(str.charAt(i));
            }
      }
      return sb.toString();
    }
}但是这里用到了额外的空间,额外用到StringBuilder进行存储
不使用额外空间

不使用额外的空间,那么我们只能在原String上进行修改了:

[*]将字符串转换成为字符数组,遍历⼀次,统计出空格的个数。
[*]对数组进行扩容,保证空格替换成%20有足够的空间:初始化的⼤⼩ = 原来的字符数组⻓度 + 空格⻓度 x 2
[*]遍历⼀次,复制,当不为空格时直接复制,当为空格时,则把 %20 这三个字符复制过去。
public class Solution {        public String replaceSpace(StringBuffer str) {                // 转换成为字符数组                char[] originChars = str.toString().toCharArray();                int spaceNum = 0;                // 计算出空格的个数                for (int i = 0; i < originChars.length; i++) {                        if (originChars == ' ') {                                spaceNum++;                        }                }                // 新字符数组的⻓度                int newCharsLength = originChars.length + 2 * spaceNum;                int newStrIndex = 0;                for (int index = 0; index

各卧唯 发表于 2025-11-18 19:45:56

懂技术并乐意极积无私分享的人越来越少。珍惜

貊淀 发表于 2025-12-20 05:27:12

感谢分享

颜清华 发表于 2026-1-10 01:54:23

谢谢分享,试用一下

勺缓曜 发表于 2026-1-13 08:42:06

前排留名,哈哈哈

能氐吨 发表于 2026-1-14 08:34:51

东西不错很实用谢谢分享

全阳霁 发表于 2026-1-22 14:16:37

感谢发布原创作品,程序园因你更精彩

洪思思 发表于 2026-1-25 08:52:24

感谢分享,学习下。

甦忻愉 发表于 2026-1-29 12:07:59

谢谢楼主提供!

旱由 发表于 2026-2-2 02:25:04

这个好,看起来很实用

摹熹 发表于 2026-2-2 03:21:41

谢谢分享,试用一下

仰翡邸 发表于 2026-2-2 04:58:29

感谢分享,学习下。

簑威龙 发表于 2026-2-3 08:02:13

感谢发布原创作品,程序园因你更精彩

马璞玉 发表于 2026-2-4 10:52:10

感谢分享,学习下。

扫恢怯 发表于 2026-2-4 11:44:27

很好很强大我过来先占个楼 待编辑

滕佩杉 发表于 2026-2-6 09:22:06

很好很强大我过来先占个楼 待编辑

哈妙思 发表于 2026-2-6 12:57:46

收藏一下   不知道什么时候能用到

卜笑 发表于 2026-2-7 08:08:01

这个有用。

吉芷雁 发表于 2026-2-7 15:55:24

用心讨论,共获提升!

撒阗奕 发表于 2026-2-8 11:12:41

鼓励转贴优秀软件安全工具和文档!
页: [1] 2
查看完整版本: 剑指offer-2、替换空格