题目 :请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。在线编程链接见:替换空格。
分析:
首先容易想到的就是从前往后扫描,如果空格,就替换为%20,但是这样需要移动空格后的元素。
还有一种方法,首先遍历一遍字符串,统计出空格的个数,并可以由此计算出替换之后的字符串的长度。每替换一个空格,长度增加2,因此替换之后的字符串长度等于原来的长度加上2乘以空格的个数。即替换后的字符串的长度 = 原字符串长度 + 空格数*2。
为了防止字符串覆盖,我们从字符串的后面开始复制和替换。我们首先准备两个指针,p1和p2。指针p1指向原字符串的末尾位置,另一个指针p2指向新字符串的末尾位置。接下来我们移动指针p1,逐个把他指向的字符复制到p2指向的位置,直到碰到一个空格为止。当碰到一个空格时,指针p1向前移动一个位置,在p2之前插入字符串”%20”,同时指针p2向前移动三个位置。
这种思路的代码如下:
void replaceSpace(char *str,int length) {
int space_num = 0;
int strlen = 0;
for(strlen=0; str[strlen]!='\0'; strlen++)
if(str[strlen] == ' ') space_num++;
int newlen = strlen + 2*space_num;
if(newlen>length) return;
while(strlen>=0){
if(str[strlen]==' '){
str[newlen--] = '0';
str[newlen--] = '2';
str[newlen--] = '%';
strlen--;
}
else str[newlen--] = str[strlen--];
}
}
当然也可以不用统计空格的个数,这时需要新建一个临时的string变量存储空格替换后的字符串,再将字符串替换为原char*数组即可,这个思路代码如下:
void replaceSpace(char *str,int length) {
string s = "";
for(int i = 0;(str)[i]!='\0';++i)
{
if((str)[i] == ' ')
{
s += '%';
s += '2';
s += '0';
}
else
s += (str)[i];
}
for(int i = s.length();i >= 0 ;--i)
(str)[i] = s[i];
}
值得注意的地方是:最后两行代码不能从前往后复制,而是要从后往前复制。如果从前往后复制会产生类似于“烫烫。。。”这样的错误。
参考资料: