本文共 1893 字,大约阅读时间需要 6 分钟。
请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy
解法一:直接调用函数
这种做法面试官看了直呼内行,然后反手把你挂了
public class Solution { public String replaceSpace(StringBuffer str) { return str.toString().replaceAll(" " , "%20"); }}
解法二:
构造一个新的字符串,遍历原字符串,把字符依次挪到新字符串,遇到空格就换成题目要求的新字符
public class Solution { public String replaceSpace(StringBuffer str) { StringBuffer newStr = new StringBuffer(); for(int i = 0; i < str.length(); i++) { if(str.charAt(i) != ' ') { newStr.append(str.charAt(i)); } else { newStr.append("%20"); } } return newStr.toString(); }}
解法三:
从前向后记录空格的数目,从后向前替换空格
0 1 2 3 4 5 6 7 8 9 10 11w e a r e l u c k y
假设空格的个数为 count,可以得知 count 为 2,所以在替换的时候,下标 7 ~ 11 的字母要向后移动 count × 2 个位置,3 ~ 5 字母要向后移动 (count - 1) × 2 个位置。 所以得到 :
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15w e a r e l u c k y w e a r e l u c k y
这时就可以直接在空格处写入 %20 了
public class Solution { public String replaceSpace(StringBuffer str) { // 计算空格数 int spaceCount = 0; for(int i = 0; i < str.length(); i++) { if (str.charAt(i) == ' ') { spaceCount++; } } // 保存下标 int index = str.length() - 1; // 扩大长度 str.setLength(str.length() + spaceCount*2); while (index >= 0) { if (str.charAt(index) != ' ') { str.setCharAt(index + spaceCount * 2, str.charAt(index)); } else { spaceCount--; str.setCharAt(index + spaceCount * 2, '%'); str.setCharAt(index + spaceCount * 2 + 1, '2'); str.setCharAt(index + spaceCount * 2 + 2, '0'); } index--; } return str.toString(); }}
总结:字符替换类的题目,要大胆假设,不要觉得想法过于复杂就放弃思考
转载地址:http://kphc.baihongyu.com/