替换字符串中的空格(C++/Java实现)

题意描述:实现一个函数把字符串中的每个空格替换成“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();	
}





你可能感兴趣的:(替换字符串中的空格(C++/Java实现))