算法考题 替换空格

参考链接

  • letcode官网题目地址

题目要求:

  • 请实现一个函数,把字符串 s 中的每个空格替换成"%20"。

示例 1:

输入:s = "We are happy."
输出:"We%20are%20happy."

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/ti-huan-kong-ge-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解决思路

时间复杂度为O(n^2)

  • 如果在先前的字符串上进行替换,就很有可能会覆盖修改该字符串后面的内存。如果创建新的字符串,并在新的字符串上进行替换,需要分配足够多的内存,
  • 时间复杂度为O(n^2)的解法,不足以拿到offer:最low的做法是从头开始扫描字符串,遇到空格就进行替换,将1个空格替换成%20,那么会造成数据的多次移动,时间复杂度很高,但是占据的内存很小,在原有的字符串上进行更改。

时间复杂度是O(n)

  • 每次替换空格,长度会增加2位,因此替换之后的长度等于先前的长度加上2*空格的数目
  • 设置两个指针,因为从0开始读取字符串,old指针第一个指针指向先前旧的字符串的长度 - 1 的位置,第二个指针new指向新的字符串 的长度减一的位置。
  • 如果old指针指向的位置是空格的话,new指针移动三次,添加”%20“,然后old移动一次
  • 如果old指针指向的位置不是空格的话,new和old指针分别移动一次,实现数据的拷贝
  • 相对于第一种方式,减少了对相同数据的拷贝次数

代码

    std::string replaceSpace(std::string s) {int old_length = s.length();if (old_length == 0){return s;}int count = 0;for (int i = 0; i < old_length; ++i) {if (s[i] == ' '){count++;}}int new_length = old_length + 2*count - 1;int original_index = old_length - 1;int new_index = new_length;s += std::string(2*count,' ');while (original_index >= 0 && new_index > original_index){if (s[original_index] == ' '){s[new_index--] = '0';s[new_index--] = '2';s[new_index--] = '%';} else{s[new_index--] = s[original_index];}--original_index;}return s;}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/446486.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python学习2 条件判断语句if,循环语句for while

顺序&#xff0c;分支&#xff0c;循环结构 条件判断语句if 1&#xff09;if…else… 2) if…elif…else 注意&#xff1a; 1&#xff09;python中不支持switch…case语句 2&#xff09;注意缩进&#xff01; 3&#xff09;区间范围内允许连续比较&#xff1a; if 1<2<…

使用VS2019创建项目,添加文件和库地址

1&#xff0c;创建项目的类型很重要&#xff0c;fisherman服务器密码机使用C语言进行开发&#xff0c;只可以使用控制台应用 将需要的头文件拷贝到新建的工程里面 然后&#xff0c;打开解决方案资源管理器&#xff0c;点击添加&#xff0c;添加现有项&#xff0c;选中拷贝的头…

java -web html5学习1

基础标签 <!--html5声明--> <!DOCTYPE html> <!--html标签--> <html lang"en"> <!--文档头--> <head> <!--告知浏览器此页面属于什么字符编码格式,--><meta charset"UTF-8"> <!-- 用于标识当前网页的…

中科大 计算机网络2 什么是互联网

概论 互联网 1&#xff09;网络–包括节点和边&#xff0c;与大小无关&#xff0c;如蜘蛛网&#xff0c;大脑神经元。。 下图的网络是一样的 2&#xff09;计算机网络 联网的计算机所构成的系统 包括主机节点&#xff08;笔记本&#xff0c;ipad,手机&#xff0c;联网的冰箱等…

虚拟机下Ubuntu配置IP地址和网段

服务器密码机的地址是172.27.120.99 ubuntu系统的IP地址是192.168.133.138&#xff0c;使用net方式和主机共享网络。现需要修改ip地址 第一步&#xff0c;net方式是不对的&#xff0c;需要选择桥接方式&#xff0c;复制物理连接状态 然后修改主机的物理连接&#xff0c;选择搜…

渔翁服务器密码机的环境配置

Linux版本 需要将配置文件 FMDevice.conf 存储到 /etc目录下需要将库文件 libfmapiv100.so 存储到 /lib64目录下编译的命令 gcc main.c ./libfmapiv100.so -lpthread -o test 需要指定 ./libfmapiv100.so&#xff0c;如果需要别的库也需要进行指定&#xff0c;比如…

王道考研 计算机网络1 计算机网络概念,组成,功能和分类

计算机网络概念&#xff0c;组成&#xff0c;功能和分类 怎样学习计算机网络 计算机网络概念 1&#xff09;网络和计算机网络区别 网络包含计算机网络&#xff08;是通信技术和计算机技术相结合的产物&#xff09; 2&#xff09;计算机网络的概念 分散的&#xff1a;指地理位…

ubuntu 修改旋转屏幕显示方向 恢复正常模式

参考链接 https://blog.csdn.net/YYshuangshuang/article/details/90576997 使用命令如下 xrandr -o normal 回到正常角度

王道考研 计算机网络2 标准化工作

标准化工作 要实现不同厂商的硬软件之间相互连通&#xff0c;必须遵从统一的标准 标准的分类&#xff1a; 法定标准&#xff1a;国内外 RFC请求评论 RFC请求评论–因特网标准 是一个因特网标准就一定是RFC形式&#xff0c;但不是所有的RFC都是因特网标准 之前的阶段&#…

二叉搜索树判定

leetcode的原文链接树的定义C版本 需要给每一个节点的数值划分范围若任意节点的左子树不空&#xff0c;则左子树上所有结点的值均小于它的根结点的值&#xff1b;任意节点的右子树不空&#xff0c;则右子树上所有结点的值均大于它的根结点的值&#xff1b;任意节点的左、右子树…

王道考研 计算机网络3 速率相关的性能指标

速率 指快慢 比特&#xff1a;1/0&#xff08;1位比特&#xff09; 速率&#xff1a;单位换算1000倍&#xff08;小写b&#xff09;&#xff0c;如&#xff0c;b/s比特每秒&#xff1b;kb/s千比特每秒 存储容量&#xff1a;单位换算1024倍(大写B)&#xff0c;如B字节&#xf…

C++ limits头文件的用法numeric_limits

参考链接 Cplus plus参考链接numeric_limits<double>::max ()是函数&#xff0c;返回编译器允许的 double 型数 最大值。类似的 numeric_limits<int>::max () 返回 编译器允许的 int 型数 最大值。需包含头文件 #include <limits> imits是STL提供的头文件&…

Linux系统运维1 运维 项目研发 网站 服务器 计算机基础 Linux操作系统

运维的基本概念 运维行业前景 企业运作模式 四大部门 项目研发流程 职责描述&#xff1a; 运维的作用&#xff1a; 网站的相关概念 网站运行流程&#xff1a; IP<–>域名 重要概念&#xff1a; 服务器图片&#xff1a; 服务器&#xff1a;为用户提供服务的机器&…

Linux 时间函数的使用

头文件 #include <chrono> #include <functional>namespace hsm { namespace common {class Timer { public:Timer();void reset();long peek_us() const;long peek_ms() const;double peek_msf() const;double record_msf(const std::function<void()> &am…

王道考研 计算机网络4 速率相关的性能指标

时延 发送时延; 发送时延;10bit 除以10b/s1s 传播时延&#xff1a; 100 m除以10m/s10s 当信道宽带提高&#xff08;发送速率&#xff09;&#xff0c;发送时延减少&#xff0c;但并不会提高传播时延–高速链路情况 总&#xff1a; 时延带宽积 描述数据量&#xff0c;链路…

std::chrono::duration_cast时间计算

参考链接 std::chrono::duration_cast

王道考研 计算机网络5 分层结构 协议 服务 接口

引入;发送文件前要准备的工作 分层的基本原则 分层结构中相关的概念 PCISDUPDU 上一层的PDU作为传给下一层的SDU,传输下去 总结

std::future详解

参考链接 cppreference.comC11之std::future对象使用说明

王道考研 计算机网络6 OSI参考模型和各层作用

计算机网络分层结构 OSI参考模型发展史 OSI参考模型 记忆&#xff1a;一个叫淑惠的女生试用物联网 OSI参考模型解释通信过程 具体操作 H代表头部 数据链路层;加了头部H2和尾部T2 物理层对数据不再处理 类似包裹;打包和拆包 应用层 如果可以不联网也能使用的程序就不属于…

std::reserves使用

参考链接 C容器使用reserve的重要性&#xff0c;以及如何释放多余内存关于vector的扩容机制