剑指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 日

相关推荐

  • Java Stream流全面指南与多样实例

    Java Stream流全方位指南与多元实例 Java Stream流最详尽教程 前言 我在日常项目中频繁使用Stream流,但对其理解尚浅,因此在此深入探究。使用Stream流时通常会涉及Java8的几项新特性,接下来我会简要介绍这些知识,以便在学习或应用Stream流时更为顺畅。 1. Lambda表达式 建议先熟悉函数式接口 1.1 语法规则 para…

    2025 年 6 月 25 日
    33500
  • Java版Aspose.Words高阶运用超全指南

    Java版Aspose.Words高级应用全面解析 Aspose.Words for Java是一款功能强劲的文档处理类库,能够让开发者开展文档的创建、修改、转换以及打印等操作。本文将会细致入微地讲解Aspose.Words for Java的高级使用途径,并且着重突出如何在文档里添加水印。 目录 Aspose.Words for Java概览 Aspose…

    2025 年 7 月 3 日
    36600
  • 全平台同步clion激活码,实用破解教程一起分享

    申明:本教程Clion破解补丁、激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除。若条件允许,希望大家购买正版 ! 废话不多说,先上 Clion2025.2.1 版本破解成功的截图,如下图,可以看到已经成功破解到 2099 年辣,舒服的很! 接下来就给大家通过图文的方式分享一下如何破解最新的Clion。 准备工作 注意:如果你之前用过…

    2025 年 12 月 21 日
    15000
  • 2024 GoLand最新激活码,GoLand永久免费激活码2025-01-04 更新

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

    2025 年 1 月 4 日
    53000
  • 🔥2025最新PyCharm永久激活码&破解教程(亲测有效,支持2099年)

    适用于JetBrains全家桶(IDEA/PyCharm/DataGrip/Goland等),Windows/Mac/Linux全平台通用! 先上成功案例✨ 我的PyCharm已经成功破解到2099年啦!👇 这篇教程将手把手教你如何用3分钟完成PyCharm永久激活!无论你是:- 🖥️ Windows用户- 🍎 Mac用户- 🐧 Linux用户- 使用任何版…

    PyCharm激活码 2025 年 6 月 26 日
    50300

发表回复

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

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

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

关注微信