设计一种方法,将一个字符串中的所有空格替换成 %20 。你可以假设该字符串有足够的空间来加入新的字符,且你得到的是“真实的”字符长度。
你的程序还需要返回被替换后的字符串的长度。
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
int blankCount = 0;
for (int i = 0;i < length;i++) {
if(string[i] == ' ') {
blankCount++;
}
}
int finalLength = (length + blankCount*2);
//char *oldPointer = string[length-1];
// char *newPointer = string[finalLength-1];
int i = length-1;
int j = finalLength - 1;
while (i != j) {
if (string[i] == ' ') {
string[j] = '0';
string[j-1] = '2';
string[j-2] = '%';
j -= 3;
} else {
string[j]=string[i];
j--;
}
i--;
}
return finalLength;
}
};
网友评论