题目描述
请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
解题思路:
首先通过遍历字符串来得到其中空格的个数;
然后,设置新的字符串的长度为:原字符串长度+2*空格数;
最后,重新遍历字符串,如果遇到空格就替换为“%20”,否则,挨着向后移动。
public class Solution {
public String replaceSpace(StringBuffer str) {
int count = 0;
for(int i=0;i<str.length();i++){
if(str.charAt(i) == ' '){
count += 1;
}
}
int subScript = str.length()-1;
int newLength = str.length()+ 2*count;
int newIndex = newLength-1;
str.setLength(newLength);
for(;subScript>=0&&subScript<newLength;subScript --){
if(str.charAt(subScript) == ' '){
str.setCharAt(newIndex--,'0');
str.setCharAt(newIndex--,'2');
str.setCharAt(newIndex--,'%');
}
else{
str.setCharAt(newIndex--,str.charAt(subScript));
}
}
return str.toString();
}
}