2. 替换空格

/* 题目描述:请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。*/
/*思路:1.从前往后,每碰到空格就做替换,由于是把1个字符替换成3个字符,所以每做一次替换,必须要把空格后面所有的字符都后移两个字节,否则就有两个字符被覆盖了。这样移动的次数太多,假设字符串的长度是n。对每个空格字符,需要移动后面O(n)个字符,因此对含有O(n)个空格字符的字符串而言,总的时间复杂度为O(n2)。
2. 从后往前。首先准备两个指针,P1和P2,P1指向原始字符串的末尾,P2指向替换之后的字符串的末尾,然后向前移动指针P1,逐个把它指向的字符复制到P2指向的位置,直到碰到空格为止,碰到了空格,就将P1向前移动1格,在P2之前插
入“%20“,同时也要把P2向前移动3格。剑指offer的46页。*/


class Solution{
public:
	void replaceSpace(char *str, int length){
		if(str == NULL || length <= 0)
			return;
		int i = 0;
		int oldlength = 0;//原来的长度
		int spacenumber = 0;//空格的数量
		while(str[i] != '\0'){
			oldlength ++;
			if(str[i] == ' '){
				spacenumber ++;
			}
			i ++;
		}
		int newlength = oldlength + spacenumber * 2;//替换后的长度
		if(newlength >= length)//这里是大于等于
			return;
		int pOldlength = oldlength;
		int pNewlength = newlength;
		while(pOldlength >= 0 && pNewlength > pOldlength){
			if(str[pOldlength] == ' '){
				str[pNewlength --] = '0';
				str[pNewlength --] = '2';
				str[pNewlength --] = '%';
			}
			else{
				str[pNewlength --] = str[pOldlength];
			}
			pOldlength --;
		}
	}
};


猜你喜欢

转载自blog.csdn.net/weixin_39605679/article/details/80863998
今日推荐