题目描述
请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
正确思路
我们采用一种时间复杂度为 O ( n ) O(n) O(n) 的方法 — 从尾到头遍历(从头到尾遍历 — 时间复杂度为 O ( n 2 ) O(n^2) O(n2))
- 先遍历一次字符串,这样就可以统计出字符串空格的总数,并可以由此计算出替换之后的字符串的总长度
- 每替换一个空格,长度增加2,因此替换以后字符串的长度等于原来的长度加上2乘以空格数目
示例:
以"We are happy"为例,“We are happy"这个字符串的长度为14(包括结尾符号”\n"),里面有两个空格,因此替换之后字符串的长度是18。
- 从字符串的尾部开始复制和替换
- 首先准备两个指针,P1和P2,P1指向原始字符串的末尾,而P2指向替换之后的字符串的末尾
- 向前移动指针P1,逐个把它指向的字符复制到P2指向的位置,直到碰到第一个空格为止
- 碰到第一个空格之后,把P1向前移动1格,在P2之前插入字串"%20"。由于"%20"的长度为3,同时也要把P2向前移动3格。
思路代码:
void replaceSpace(char *str,int length) {
if(str == NULL ||length<=0) return;
int sz = 0, count = 0;
for(int i=0;str[i]!='\0';i++)
{
if(str[i] == ' ') count++;
sz++;
}
int new_sz = sz+count*2;
int i = sz;
int j = new_sz;
while(sz>=0 && j>i)
{
if(str[i] == ' ')
{
str[j--] = '0';
str[j--] = '2';
str[j--] = '%';
}
else
str[j--] = str[i];
i--;
}
}
C/C++题解代码
char* replaceSpace(char* s){
if(*s == '\0') return s;
char *res = (char *)malloc(strlen(s)*3+1);
int i = 0;
while(*s != '\0'){
if(*s == ' '){
res[i++] = '%';
res[i++] = '2';
res[i++] = '0';
}else{
res[i++] = *s;
}
s++;
}
res[i] = '\0';
return res;
}
string replaceSpace(string s) {
int count = 0, len = s.size();
// 统计空格数量
for (char c : s) {
if (c == ' ') count++;
}
// 修改 s 长度
s.resize(len + 2 * count);
// 倒序遍历修改
for(int i = len - 1, j = s.size() - 1; i < j; i--, j--) {
if (s[i] != ' ')
s[j] = s[i];
else {
s[j--] = '0';
s[j--] = '2';
s[j] = '%';
}
}
return s;
}
如有不同见解,欢迎留言讨论~~~