剑指offer之空格替换
题目描述:
请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
偷懒实现:
public class Solution {
public String replaceSpace(StringBuffer str) {
for (int i = 0; i <str.length() ; i++) {
if (str.charAt(i) == ' '){
str.replace(i, i+1,"%20");
}
}
return str.toString();
}
}
时间复杂度为O(N)的实现:
package com.anran.offer;
public class ReplaceSpace {
/**
* 时间复杂度为O(n)
* 思路:设置两个指向新字符串尾部和原数组尾部的指针,两个指针同时从
* 尾部向前扫描,若原字符串碰到空格,为新数组插入02%三个字符,
* 否则将元字符串的字符拷贝到新字符串。
* @param str
* @return
*/
public String replaceSpace(StringBuffer str) {
// 获取替换空格后字符串的长度
int newlength = str.length() + findSpace(str) * 2;
int indexold = str.length() - 1;
int newindex = newlength-1;
StringBuffer newStr = new StringBuffer();
newStr.setLength(newlength);
for (; indexold >= 0 && indexold < newlength; --indexold) {
if (str.charAt(indexold) == ' ') {
newStr.setCharAt(newindex--, '0');
newStr.setCharAt(newindex--, '2');
newStr.setCharAt(newindex--, '%');
} else {
newStr.setCharAt(newindex--, str.charAt(indexold));
}
}
return newStr.toString();
}
// 返回空格的个数
public int findSpace(StringBuffer str) {
int count = 0;
for (char s : str.toString().toCharArray()
) {
if (s == ' ') {
count++;
}
}
return count;
}
public static void main(String[] args) {
StringBuffer str = new StringBuffer("hello world");
String s = new ReplaceSpace().replaceSpace(str);
System.out.println(s);
}
}