首页 > 基础资料 博客日记
剑指offer-2、替换空格
2025-06-13 09:30:02基础资料围观341次
文章剑指offer-2、替换空格分享给大家,欢迎收藏Java资料网,专注分享技术知识
题目描述
请实现一个函数,将一个字符串中的空格替换成“%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[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);
}
}
文章来源:https://www.cnblogs.com/seven97-top/p/18916767
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
相关文章
最新发布
- 曝华为"白嫖"开源团队技术方案事件——网友评论总结
- 洛谷-P7998 [WFOI - 01] 猜数 题解
- AI 相关概念之(基础层级):AI、ANI、AGI、ASI
- 深度解读 AEC-Q100 Rev-J:为什么先进制程芯片的 ESD 电压降低?车规标准“放水”了?
- 硅基流动 vs OpenRouter——两种AI Infra模式的取舍
- Vector 选型与实战:vs OTel / Logstash / Fluentd 全维对比,及统一日志与指标管道的 AWS ECS 落地
- "MixFormer: Co-Scaling Up Dense and Sequence in Industrial Recommenders" 论文笔记
- 开源分享|用MicroPython 做了个 AI 小鸡,它会长大,还记得我所有的情绪
- HEIC图片转换器(HEIC转JPG/PNG/WEBP/BMP/TIFF/ICO)
- 5 分钟上手 AgentRun:从注册到第一个 Agent 运行

