- 问题描述
请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy
2.思路解析
我们可以创建一个新的字符串,也可以在原字符串基础上修改,但是要保证字符串后边有足够多的空余内存。
如果从前往后扫描字符串,遇到空格,就要将后边的字符依次向后移动两个字节,时间复杂度为O(n2)。
如果从前往后扫描字符串,记录下空格的个数,那么就知道了新字符串的长度,然后从新字符串的末尾向前开始复制和替换。设置两个指针,分别指向源位置和目的位置,当二者重合时,意味着复制完成。
3.C++代码
class Solution { public: void replaceSpace(char *str,int length) { if (str==NULL || length<0) return; int strlength = 0, spacenum = 0; for(int i=0; str[i]!='\0';i++){ strlength++; if(str[i]==' ') spacenum++; } if (spacenum == 0) return; int newlength = strlength+2*spacenum; if (newlength > length-1) return; while(strlength>=0 && strlength<newlength){ if (str[strlength]==' '){ strlength--; str[newlength--]='0'; str[newlength--]='2'; str[newlength--]='%'; } else{ str[newlength--] = str[strlength--]; } } return; } };
4.总结
合并两个字符串或数组时,如果从前往后复制需要移动的次数很多时,可以考虑从后往前复制。