设计一种方法,将一个字符串中的所有空格替换成 %20 。你可以假设该字符串有足够的空间来加入新的字符,且你得到的是“真实的”字符长度。
你的程序还需要返回被替换后的字符串的长度。
样例
对于字符串”Mr John Smith”, 长度为 13
替换空格之后,参数中的字符串需要变为”Mr%20John%20Smith”,并且把新长度 17 作为结果返回。
挑战
在原字符串(字符数组)中完成替换,不适用额外空间
解题思路:先计算出更新之后数组的长度,然后从后向前遍历替换数组元素。
一刷ac
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) {
if(string == null || string.length == 0) return 0;
int result = length;
for(int i = 0; i < length; i++){
if(string[i] == ' ') result += 2;
}
int index = result - 1;
length = length - 1;
while(index >= 0){
if(string[length] == ' '){
string[index--] = '0';
string[index--] = '2';
string[index--] = '%';
}else{
string[index] = string[length];
index--;
}
length--;
}
return result;
}
}