时间:2022-11-10 09:23:07 | 栏目:C代码 | 点击:次
请实现一个函数,把字符串 s 中的每个空格替换成"%20"。
示例:
输入:s = "We are happy."
输出:"We%20are%20happy."
限制:0 <= s 的长度 <= 10000
思路
C语言的字符串无法改变大小,所以无法直接在原来的字符串上操作。于是我们先统计空格个数,算出替换后的字符串的大小,并申请一块新内存。(注意要多申请一个byte,放字符串结尾符’\0’)。再次遍历这个字符串,将空格替换成%20。
算法流程:首先得到字符串s的长度
遍历这个字符串,统计空格个数
计算新的字符串需要的空间,并申请一块新内存
遍历字符串s,如果没有空格则进行正常赋值。如果碰到空格,则在新字符串对应的三个位置放上%20
整体代码如下
char* replaceSpace(char* s){ int count = 0; int len = 0; while(s[len] != '\0'){ len++; } int i = 0; for(i = 0; i < len; i++){ if(s[i] == ' '){ count++; } } char* str = (char*)malloc(sizeof(char)*(len + 1 + count * 2)); int j = 0; for(i = 0; i < len; i++, j++){ str[j] = s[i]; if(s[i] == ' '){ str[j++] = '%'; str[j++] = '2'; str[j] = '0'; } } str[j] = '\0'; return str; }
运行,测试通过