【剑指offer】-替换空格-02/67(JAVA版本未写)

简介: 【剑指offer】-替换空格-02/67(JAVA版本未写)

题目描述:

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

题目分析

  1. 从前向后记录空格(count) 数目,从后向前替换空格
  2. 重点:从后向前替换的时候的技巧 例如:“we are lucky”
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
w e   a r e   l u c  k y 
w e % 2 0 a r e % 2  0 l u c k y

可以得知count=2;。 所以在替换的时7-11的字母要向后移动count×2个位置,3-5字母要向后移动(count-1)×2个位置。

代码(c++)

class Solution {
public:
  void replaceSpace(char *str,int length)
    {
        int count = 0;
        for(int i = 0; i < length; i++)
        {
            if(str[i] == ' ')
            {
                count++;
            }
        }
        for(int i = length - 1; i >= 0; i--)
        {
            if(str[i] == ' ')
            {
                  str[2 * count + i] = '0';
                  str[2 * count + i - 1] = '2';
                  str[2 * count + i - 2] = '%';
                  count--;
            }
            else
            {
                str[2 * count + i] = str[i];
            }
        }
    }
};
//运行时间:8ms
//占用内存:508k

总结

  1. 分析问题一定要全面分析,充分考虑复杂度和时间的问题。
  2. 用JAVA语言来写这道题,还有太多的不足,等学完JAVA在来补上这道题。


相关文章
|
4月前
|
Java 中间件 测试技术
java依赖冲突解决问题之jar包版本冲突无法通过升降级解决时如何解决
java依赖冲突解决问题之jar包版本冲突无法通过升降级解决时如何解决
|
1月前
|
Java Linux Windows
如何查看已安装的 Java 版本
要查看已安装的 Java 版本,打开命令提示符或终端,输入 `java -version`,回车后即可显示当前系统中 Java 的版本信息。
257 1
|
1月前
|
Ubuntu Java Linux
如何检查 Java 版本是否兼容
要检查Java版本是否兼容,可在命令行输入“java -version”查看当前安装的Java版本,然后对比目标应用所需的Java版本,确保其满足要求。
69 1
|
2月前
|
缓存 Java Maven
java: 警告: 源发行版 11 需要目标发行版 11 无效的目标发行版: 11 jdk版本不符,项目jdk版本为其他版本
如何解决Java项目中因JDK版本不匹配导致的编译错误,包括修改`pom.xml`文件、调整项目结构、设置Maven和JDK版本,以及清理缓存和重启IDEA。
61 1
java: 警告: 源发行版 11 需要目标发行版 11 无效的目标发行版: 11 jdk版本不符,项目jdk版本为其他版本
|
2月前
|
Java Docker 容器
java版本学习网站又添加了一个libgdx模块
java版本学习网站之前添加了docker,想了想还是再把libgdx添加进去吧。
35 3
|
3月前
|
Java
java版本详解
java版本详解
|
2月前
|
Java Maven Spring
查看springboot版本支持最高的java版本
截至最近更新,Spring Boot 3.0及以上版本支持的最高Java版本为Java 17。鉴于技术的不断演进,建议直接参考Spring Boot的官方文档获取最准确的支持信息,因为这些版本兼容性可能会随着新版本的发布而有所变化。选择与你的Spring Boot版本相匹配的Java版本,可以确保充分利用框架特性,同时保证项目的稳定性和前瞻性。
92 0
|
2月前
|
Java Linux Maven
用sdkman在linux上管理多个java版本
本文介绍了如何在Linux上使用SDKMAN来管理多个Java版本,包括安装SDKMAN、验证安装、列出和安装不同版本的JDK、Maven和Gradle,以及如何切换使用不同版本。
72 0
|
3月前
|
Java API 开发工具
Java不同的版本
Java不同的版本Java不同的版本
43 4
|
3月前
|
Java API 开发工具
Java版本
Java版本
56 2
下一篇
DataWorks