实现一个函数,把字符串中的每个空格替换成"%20"。例如输入"we are happy",则输出"we%20are%20happy".
思路:看到这个题目,我们首先想到的是原来一个字符串,替换之后成为'%','2','0'三个字符串,因此字符串会变长,我们有两种方法可以实现替换,一是在原有的 字符串上替换,则有可能覆盖修改在该字符串后面的内存。二是创建新的字符串并在新的字符串上做替换。
第一种方法是在原有字符串上做替换,从头到尾遍历字符串,每一次遇到空格的时候做替换,由于把一个字符替换成三个,所以替换时必须把空格后面的字符都向后移动两个字节,遇到第二个空格,第二个空格后的字符又要移动两个字节,以此类推,每次遇到空格时,空格后面的字符都要向后移动两个。会增加时间复杂度。
第二种方法是创建新的字符串,我们先遍历一遍字符串,每次的空格用count标记,找到空格的总数,并且可以计算出替换之后字符串的总长度。就本题而言,创建新的字符串的长度为newend=oldend+count*2,我们可以将newend和oldend看成两个数组,用两个数组的下标进行替换,while(oldend<newend),如果str[oldend]!=' '的时候,将oldend的最后一个给newend的最后一个,倒数第二个给新的倒数第二个,以此类推,当遇到空格时,将'0','2','%'依次附上去,oldend的下标——。
代码实现如下:
#include <stdio.h> #include <string.h> void change (char *str) { int len=strlen(str); int count=0; int oldend=len; int newend; char *ptr = str; while (*ptr!='\0') { if(*ptr==' ') { count++; } ptr++; }//遍历数组,找到空格数 newend=oldend+count*2;//创建新的长度 while(oldend<newend) { if (str[oldend] != ' ') { str[newend--] = str[oldend--]; } else { str[newend--] = '0'; str[newend--] = '2'; str[newend--] = '%'; oldend--; } } } int main() { char arr[30]="we are happy."; change (arr); puts(arr); return 0; }