牛客网-替换空格简单解答

描述

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

替换空格_牛客题霸_牛客网
本道题的思路可以理解为我们先将整个字符串中的空格数量找到,然后按照我们空格的数量来计算我们新生成的数组所需要的空间的大小。(原来字符串中为' '的地方我们全部需要替换为%20,所以,我们统计了空格的个数之后,增长的字符串长度为空格的个数×(3-1))

第二部,我们需要安排两个尾指针,一个len1指向原来的字符串的末位位置,另一个len2指向我们新生成的字符串的末位位置,然后如果len1和len2都不是空的字符,我们就将len1所指向的字符赋值给len2所指向的位置。如果len1所指向的位置为' '(空格),那么我们len2指针所指向的位置需要将'%20‘放入,也就是说要往前走三步,与此同时,len1往前走一步。

最后,当我们的len1和len2所指向的位置相同的时候,就代表我们的字符串中的空格全部都被替换完成了,此刻就可以结束我们的程序了

class Solution {
public:
	void replaceSpace(char *str,int length) {
        //数空格
		int spacecnt=0;
		char*p=str;
		while(*p)
		{
			if(*p==' ')
				spacecnt++;
			p++;
		}
		int newlen=length+2*spacecnt;//计算新的长度的个数
		int end1=length-1;
		int end2=newlen-1;
		
		while(end1!=end2)
		{
			if(str[end1]!=' ')
			{
				str[end2--]=str[end1--];
			}
			else
			{
				str[end2--]='0';
				str[end2--]='2';
				str[end2--]='%';
				end1--;
			}
		}

	}
};

 

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

桜キャンドル淵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值