设计一种方法,将一个字符串中的所有空格替换成 %20
。你可以假设该字符串有足够的空间来加入新的字符,且你得到的是“真实的”字符长度。
你的程序还需要返回被替换后的字符串的长度。
注意事项
如果使用 Java 或 Python, 程序中请用字符数组表示字符串。
对于字符串"Mr John Smith"
, 长度为 13
替换空格之后,参数中的字符串需要变为"Mr%20John%20Smith"
,并且把新长度 17
作为结果返回。
class Solution {
public:
/*
* @param string: An array of Char
* @param length: The true length of the string
* @return: The true length of new string
*/
int replaceBlank(char string[], int length) {
// write your code here
if(string==NULL){
return 0;
}
char a,b;
int sum=0;
for(int i=0;string[i]!='\0';i++){
sum++;
}
for(int i=0;string[i]!='\0';i++){
if(string[i]==' '){
for(int j=sum-1;j>i;j--){
string[j+2]=string[j];
}
sum+=2;
string[i]='%';
i++;
string[i];
string[i]='2';
i++;
string[i];
string[i]='0';
length+=2;
}
}
return length;
}
};