JZ2 替换空格
题目描述
请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
思路
从前往后数空格数,从后往前进行移动(注意不能从前往后移,因为会把后面的覆盖)
不能用string的字符串插入insert,因为这个不是C++的容器string

代码
class Solution {
public:
void replaceSpace(char *str,int length) {
int space=0;
int i=0;
for(;i<length;i++)
{
if(str[i]==' ')
space++;
}
for(;i>=0;i--)
{
if(str[i]!=' ')
str[i+2*space]=str[i];
else
{
str[i+2*space]='0';
str[i+2*space-1]='2';
str[i+2*space-2]='%';
space--;
}
}
}
};