設(shè)計一種方法驹止,將一個字符串中的所有空格替換成 %20 窑邦。你可以假設(shè)該字符串有足夠的空間來加入新的字符拜英,且你得到的是“真實的”字符長度垢油。
你的程序還需要返回被替換后的字符串的長度盆驹。
注意事項
如果使用 Java 或 Python, 程序中請用字符數(shù)組表示字符串。
您在真實的面試中是否遇到過這個題滩愁?
Yes
樣例
對于字符串"Mr John Smith", 長度為 13
替換空格之后躯喇,參數(shù)中的字符串需要變?yōu)?Mr%20John%20Smith",并且把新長度 17 作為結(jié)果返回硝枉。
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
int BlankNums=0;
for(int i=0;i<length;i++){
if(string[i]==' '){
BlankNums++;
}
}
int Strlen=length+BlankNums*2;
int diff=BlankNums*2;
for(int i=length-1;i>=0;i--){
if(string[i]!=' '){
string[i+diff]=string[i];
}
else{
string[i+diff]='0';
diff--;
string[i+diff]='2';
diff--;
string[i+diff]='%';
}
}
return Strlen;
}
};