题目:请实现一个函数,把字符串中的每个空格替换成"%20"。例如,输入“We are happy.”,
则输出“We%20are%20happy.”。
前期分析:
在拿到题之后 首先是与字符串肯定要与数组或者指针有关系,如果要把字符串所有空格替换成%20的话 空格占一个字符串数组的位置的话%20肯定要占三个,所以字符串的长度是肯定要增加的,增加多少呢 一个空格要增加2个长度,所以增加后的字符串长度值就是原来的长度值加上空格个数乘以2。
整体思想:
定义两个数组的标志位,p1 和 p2 ,p1 的位置是原始字符串的末尾,p2的位置是增加空格后的字符串末尾,接下来p1开始减少移动,逐个在移动的过程中的字符复制到p2移动的位置,直到p1减少移动到第一个空格为止,当遇到第一个空格后,p1还需要向前移动1格,此时在p2的位置插入%20,这个长度是3 所以p2需要移动3个,第一次循环就结束了 ,下面就可以继续按照第一次的方式进行复制直到p1 与 p2相等的时候,限制条件是 你必须要输入一个字符串,并且p2不能大于p1 当两者相等时候说明没有空格了 。
要想程序的时间复杂度为O(n)的话可以尝试从后面进行复制和替换
上代码:
#include#include void replace_str(char arg[],int length){ if (arg == NULL || length <= 0) { printf("入参为空,请检查%s,[%d]n",__func__,__LINE__); return; } int old_size = 0;//原本的长度 int new_size = 0;//增加后的长度 int count_num= 0;//记录空格的个数 int i=0; while (arg[i] !=' ') { ++old_size; if(arg[i]==' '){ ++count_num; } ++i; } new_size = old_size + count_num*2; if(new_size > length){ //防止越界段错误 return; } int p_old =old_size; int p_new =new_size; while(p_old >= 0 && p_new > p_old ){ //p_old可以等于0是为了 输入字符串的时候可以是单一的一个空格,就可以转换成%20 if(arg[p_old] == ' '){ arg[p_new--]='0'; arg[p_new--]='2'; arg[p_new--]='%'; }else{ arg[p_new--]=arg[p_old]; } --p_old;//因为需要多移动一次选择使用--p_old } } int main(int argc, char const *argv[]) { char arr[100]={0}; printf("请输入一个含有空格的字符串 >n"); fgets(arr,100,stdin); arr[strlen(arr)-1]=' ';//吃掉输入的回车,不然在输出的时候会多打印一个空行 replace_str(arr,100); printf("%sn",arr); return 0; }



