提示
LintCode中的相关算法题实现代码,可以在我的GitHub中下载。
题目需求
设计一种方法,将一个字符串中的所有空格替换成 %20
。你可以假设该字符串有足够的空间来加入新的字符,且你得到的是“真实的”字符长度。
你的程序还需要返回被替换后的字符串的长度。
样例
对于字符串"Mr John Smith"
, 长度为 13
替换空格之后,参数中的字符串需要变为"Mr%20John%20Smith"
,并且把新长度 17
作为结果返回。
挑战
在原字符串(字符数组)中完成替换,不适用额外空间
解题思路
先计算空格的数量,替换后的数组长度是原来的长度加上空格数量的2倍,然后向后向前移动,替换空格即可。
实现代码
class Solution {
public:
/*
* @param string: An array of Char
* @param length: The true length of the string
* @return: The true length of new string
*/
int replaceBlank(char string[], int length) {
// write your code here
if(length==0) return 0;
int count=0;
int i=0;
int low=length;
while(string[i]!='\0')
{
if(string[i]==' ') count++;
i++;
}
length+=2*count;
int high=length;
while(low>=0)
{
if(string[low]!=' ')
{
string[high]=string[low];
high--;
}
else
{
string[high--]='0';
string[high--]='2';
string[high--]='%';
}
low--;
}
return length;
}
};