剑指面试题5-替换空格

题目:请实现一个函数,把字符串中的每个空格替换成“%20”。例如,输入“We are happy.”,则输出“We%20are%20happy.”。

分析: 首先要搞清楚面试官的问题,是改变原字符串还是重新创建。
(1)时间复杂度为O(n^2)的解法 不足以拿到offer
从头到尾遍历字符串,每遇到一个空格替换一次,替换一个空格后面的字符需要移动O(n)次,n个空格所以时间复杂度为o(n^2)
(2)时间复杂度为O(n)的解法
首先准备两个指针 p1 和p2 最后的目的是让两个指针位置相同来判断是否替换完成。首先计算替换完 之后总的长度,为原长度加空格的数目乘2.
we are happy. 原长度为14 总长度=14+2*2=18
p1指针指向原字符末尾,p2指针指向总长末尾 此p1 =13 p2=17
此时开始移动p1的位置,把p1指向的字符移动到p2的位置,直到遇到第一个空格,然后p1向前移动一个,p2向前移动需要替换的字符个数,即3个 重复此操作 直到p1=p2

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值