设计一种方法,将一个字符串中的所有空格替换成 %20
。你可以假设该字符串有足够的空间来加入新的字符,且你得到的是“真实的”字符长度。
你的程序还需要返回被替换后的字符串的长度。
注意事项
如果使用 Java 或 Python, 程序中请用字符数组表示字符串。
样例
对于字符串"Mr John Smith"
, 长度为 13
替换空格之后,参数中的字符串需要变为"Mr%20John%20Smith"
,并且把新长度 17
作为结果返回。
解决:先计算替换后的最大长度,从后遍历字符串,逐步后移
public class Solution {
/**
* @param string: An array of Char
* @param length: The true length of the string
* @return: The true length of new string
*/
public int replaceBlank(char[] string, int length) {
// Write your code here
if(0==length) return length;
int blankNums = 0;
for(int i = 0; i < length; ++i){
if(string[i] ==' ')
blankNums++;
}
int strlen = length+blankNums*2; //获取替换后的总长度
string[strlen]=0;
int j=1;
for(int i = length-1;i>=0;i--){
if(string[i] != ' '){ //如果当前不是空格,则把该字符放入后面
string[strlen-j] = string[i];
j++;
}
else{
string[strlen-j] = '0';
j++;
string[strlen-j] = '2';
j++;
string[strlen-j] = '%';
j++;
}
}
return strlen;
}
}