题目描述
请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
class Solution {
public:
void replaceSpace(char *str,int length) {
if(str==NULL||length<=0) return ;
for (int i=0;i<length;){
if(str[i]==' '){ //空格
length+=2; //先将数组长度加2
int j=length-1;//从后向前,将i+1之后的元素全部向后移动2位
while(j>i+2){
str[j]=str[j-2];
j--;
}
str[i]='%';
str[i+1]='2';
str[i+2]='0';
i=j+1; //下次判断从向后移动的最后一个字符开始,即第i+3个
}
else i++;
}
}
};