剑指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来存储内容。

不使用额外空间

若不使用额外空间,那就得在原字符串上进行修改:

  1. 将字符串转换成字符数组,遍历一次来统计空格的个数。
  2. 对数组进行扩容,保证空格替换成“%20”时有足够的空间:新的长度 = 原来的字符数组长度 + 空格个数×2。
  3. 再次遍历,进行复制操作,遇到非空格字符就直接复制,遇到空格时,就把“%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[i] == ' ') {
                spaceNum++;
            }
        }
        // 新字符数组的长度
        int newCharsLength = originChars.length + 2 * spaceNum;
        int newStrIndex = 0;
        for (int index = 0; index <= originChars.length - 1; index++) {
            if (originChars[index] != ' ') {
                // 直接复制
                newChars[newStrIndex++] = originChars[index];
            } else {
                // 空格则需要复制三个字符
                newChars[newStrIndex++] = '%';
                newChars[newStrIndex++] = '2';
                newChars[newStrIndex++] = '0';
            }
        }
        // 转成字符串
        return new String(newChars);
    }
}

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/12610.html

(0)
LomuLomu
上一篇 2025 年 6 月 22 日
下一篇 2025 年 6 月 22 日

相关推荐

  • datagrip破解免联网模式与激活码教程

    本文同样适用于 IntelliJ IDEA、PyCharm、GoLand、WebStorm 等 JetBrains 全系列,亲测有效! 先放一张成功截图镇楼——DataGrip 已经顺利解锁到 2099 年,爽翻! 下面我就一步步带你搞定 DataGrip 的永久激活,旧版同样通用,Windows / macOS / Linux 全平台都打包好了。 1. 获…

    DataGrip激活码 2025 年 11 月 13 日
    20000
  • 2025年最新DataGrip激活码与永久破解方法(支持2099年)

    Jetbrains全家桶通用破解指南 今天为大家带来一个超实用的技术教程,适用于DataGrip、PyCharm、IDEA等Jetbrains系列开发工具的永久激活方案。先看效果图,我的DataGrip已经成功激活至2099年! 本教程将详细讲解如何一步步实现DataGrip的永久激活,该方法兼容多个版本,无论Windows、Mac还是Linux系统都能完美…

    DataGrip激活码 2025 年 8 月 1 日
    26600
  • 2024 GoLand最新激活码,GoLand永久免费激活码2024-12-29 更新

    GoLand 2024最新激活码 以下是最新的GoLand激活码,更新时间:2024-12-29 🔑 激活码使用说明 1️⃣ 复制下方激活码 2️⃣ 打开 GoLand 软件 3️⃣ 在菜单栏中选择 Help -> Register 4️⃣ 选择 Activation Code 5️⃣ 粘贴激活码,点击 Activate ⚠️ 必看!必看! 🔥 获取最新激活…

    2024 年 12 月 29 日
    59900
  • 无需额外下载最新版datagrip激活码,一键破解教程

    声明:以下破解补丁、激活码均收集于网络,仅限个人学习研究,禁止商用。若条件允许,请支持正版!如有侵权,请联系我删除。 先放张图镇楼——DataGrip 2025.2.1 已顺利解锁到 2099 年,爽歪歪! 下面用图文手把手教你搞定最新版 DataGrip 的激活流程。 嫌折腾?官方正版全家桶低至 32 元/年,直接登录即用:https://panghu.h…

    2025 年 10 月 19 日
    12800
  • 最新datagrip破解视频讲解+永久激活码配置

    免责声明:下文所述 DataGrip 2025.2.1 破解补丁与激活码均源自网络公开资源,仅限个人学习研究,禁止商业用途。若遇版权争议,请立即联系作者删除。条件允许时,请支持正版! 先放一张“战果”:DataGrip 已成功激活到 2099 年,爽歪歪! 下面用图文方式手把手带你完成最新版 DataGrip 的激活流程。 嫌折腾?官方正版全家桶低至 32 …

    DataGrip激活码 2025 年 11 月 12 日
    13400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信