【剑指offer】第二题

题目描述

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

 

第一种思路,开辟一个新的内存存修改后的字符串(时间复杂度为o(n))

class Solution {
public:
	void replaceSpace(char *str,int length) {
        const int maxn = 100000+1;
        char nowStr[maxn] = {'1'};
         int count = 0;
         for(int i = 0;i < length;++i)
         {
             if(str[i] == ' ')
             {
                 nowStr[count++] = '%';
                 nowStr[count++] = '2';
                 nowStr[count++] = '0';
             }
             else
                 nowStr[count++] = str[i]; 
         }
        strcpy(str,nowStr);
	}
};

第二种思路:从后往前搜,遇到空格原字符串整体向后移三格,用来填充%20

class Solution {
public:
	void replaceSpace(char *str,int length) {
       
        int i=length-1,j,count=0;
        while(i>=0){							//从后往前扫描字符串
            if(str[i]==' '){						//如果扫描到字符是空格
                for(j=length;j>=i;j--){			//将字符串从空格到最后的'\0'都往后移动两个位置,因为要塞 %20
                    str[j+2]=str[j];		
                }
            	str[i]='%';			//i就是空格的位置,放%
            	str[i+1]='2';		  //i+1放2
            	str[i+2]='0';			// i+2放0
            	length+=2;			//长度要加二
            }
             i--;
        }
        
};

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值