题意描述:实现一个函数把字符串中的每个空格替换成“20%”。例如:
输入:“we are happy”
输出:“we%20are%20happy”
解题思路:(C++实现方法)如果从前往后遍历,遇到空格再将字符向后移动,则假设有O(n)个空格的时间效率就是O(n^2)。因此优化的解法就是一次移到位,先遍历一次字符串,可同时得到字符串的长度和字符串中空格的数量,然后对于1个空格用“%20”这3个字符替换,所以可以计算出最终字符串应该有的长度,两个指针,一个指向最终字符串的末尾,一个指向原始字符串的末尾,依次复制,遇空格便替换,当两指针重合(即指向同一位置),则说明空格替换完毕。如此做法时间效率就是O(n)
void replaceBlank(char string[], int length) {//length为字符数组的总容量
if (string == NULL || length <= 0)
return;
int originalLength = 0;//字符串的原长度
int numberOfBlank = 0; //空格个数
int i = 0;
while (string[i] != '\0') {
originalLength++;
if (string[i] == ' ')
numberOfBlank++;
i++;
}
int newLength = originalLength + numberOfBlank * 2;//新字符串的长度
if (newLength > length)
return;
int indexOfOriginal = originalLength;
int indexOfNew = newLength;
while (indexOfOriginal >= 0 && indexOfNew >= indexOfOriginal) {
if (string[indexOfOriginal] == ' ') {
string[indexOfNew--] = '0';
string[indexOfNew--] = '2';
string[indexOfNew--] = '%';
}
else {
string[indexOfNew--] = string[indexOfOriginal];
}
indexOfOriginal--;
}
}
(Java实现方法)
//解题思路一:借助Java API中的replaceAll函数直接实现替换
public static String replaceSpace(String str) {
String regex = " ";
return str.replaceAll(regex, "%20");
}
//解题思路二:遍历字符串,遇到空格就替换
public static String replaceSpace1(String str){
StringBuilder sb = new StringBuilder(str);
for(int i=0; i<sb.length(); i++){
if(sb.charAt(i) == ' ')
sb.replace(i, i+1, "%20");
}
return sb.toString();
}