JZ2-替换空格

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

【解题】
此题官方解法与《剑指offer》思路相同。

方法: 逆向遍历
在这里插入图片描述

1.分析:由于函数返回为void,说明此题不能另外开辟数组,需要in-place操作。我们知道字符串的遍历无非是从左到右和从右到左两种。
1)如果从左到右,会发现如果遇到空格,会将原来的字符覆盖。于是,此方法不行。
2)那么就考虑从右向左,遇到空格,就填充“20%“,否则将原字符移动应该呆的位置。

在这里插入图片描述
在这里插入图片描述

class Solution {
public:
	void replaceSpace(char *str,int length) {
        if(str==nullptr||length<=0){//养成良好习惯,判断是否为空操作
            return;
        }
        int cnt = 0;//空格个数
        for(int i=0;i !=length;++i){//i<length与i!=length一样
            if(str[i]==' '){
                ++cnt;
            }
        }
        if(!cnt) return;
        int new_length=length+2*cnt;
        for(int i=length;i>=0;--i){
            if(str[i]==' '){
                str[new_length--]='0';//注意!!这里一定不能是new_length-1,那样不对,
                str[new_length--]='2';//应该是先用再减。
                str[new_length--]='%';
            }
            else{
                str[new_length--]=str[i];
            }
        }
	}
};

注意:i++和++i相同,在for里面,都是当每次for循环执行后再++操作。但是在for循环操作中就不一样了!
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

B站视频代码原理也是如此,只是代码简洁一些。

class Solution {
public:
	void replaceSpace(char *str,int length) {
        int count = 0;
        
        for(int i = 0; i < length; i ++)
        {
            if(str[i] == ' ')
                count ++;
        }
        // 1
        //%20 3
        for(int i = length - 1; i >= 0; i --)
        {
            if(str[i] != ' ')
                str[i + count * 2] = str[i];
            if(str[i] == ' ')
            {
                count --;
                str[i + count * 2] = '%';
                str[i + count * 2 + 1] = '2';
                str[i + count * 2 + 2] = '0';
            }
        }
        
    }
};

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值