剑指offer:替换空格

2023-02-12,,,

题目描述:

请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。

思路:

一开始没理解,函数中给的参数length指的字符串长度,原来表示的是这个字符串的最大长度。参考了网上的题解,说明一下思路。

最原始的想法自然就是从头遍历字符串,遇到空格,就将空格后的字符向后移动,再插入“%20”,但是这样的复杂度为O(n^2),考虑到其实每次替换的过程中后面的字符重复做后移操作。所以考虑从后往前遍历,记录出现的空格总数,再求新字符串的总长度。

使用两个指针,做替换操作,第一个指针指向原始字符串的末尾,第二个指针指向新字符串末尾,从后往前遍历原始字符串,若当前字符为空格,则用第二个指针在新字符串中从后往前的插入“%20”,否则将第一个指针所指向的元素复制到第二个指针的位置。

注意点:

对字符串的处理都应该考虑最后的空字符’\0’。

空指针判断nullptr。

一般像这种需要向后扩充容量重新整理内存的,最好能够考虑到从尾部开始整理的方法。

代码:

class Solution {
public:
void replaceSpace(char *str,int length) {
if(str==nullptr || length==)
return;
int len_str=;
int blank=;
int i=;
while(str[i]!='\0')
{
len_str++;
if(str[i]==' ')
blank++;
i++;
}
int new_len = len_str + *blank;
if(new_len>length)
return;
while(len_str>= && new_len>len_str)
{
if(str[len_str]==' ')
{
str[new_len--] = '';
str[new_len--] = '';
str[new_len--] = '%';
}
else
{
str[new_len--] = str[len_str];
}
len_str--;
}
return;
}
};

剑指offer:替换空格的相关教程结束。

《剑指offer:替换空格.doc》

下载本文的Word格式文档,以方便收藏与打印。