链接:https://leetcode.cn/problems/reverse-words-in-a-string/
给你一个字符串 s ,请你反转字符串中 单词 的顺序。
单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。
返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。
注意:输入字符串 s中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。
示例 1:
输入:s = "the sky is blue"
输出:"blue is sky the"
示例 2:
输入:s = " hello world "
输出:"world hello"
解释:反转后的字符串中不能存在前导空格和尾随空格。
示例 3:
输入:s = "a good example"
输出:"example good a"
解释:如果两个单词间有多余的空格,反转后的字符串需要将单词间的空格减少到仅有一个。
解决这道题,思路可分三步
步骤一:删除字符串中的多余空格(前导空格、单词间的多个空格、尾随空格);
步骤二:反转整个字符串;
步骤三:反转字符串里面的单词。
接下来一步一步看
步骤一:删除字符串中的多余空格
(1)前导空格好删除。定义一个指针,从头开始遍历,当前面是非空格时停止即可。
(2)单词间的多个空格。跳过连着的空格即可(这里处理完,尾部最多还剩一个空格或者没有空格)
(3)尾随空格。去掉末尾的空格
完整代码
// 删除空格
void removeSpace(string& str) {
int slow = 0, fast = 0, len = str.length();
// 去掉前面的空格
while (len > 0 && fast < len && str[fast] == ' ') {
fast++;
}
// 去掉中间的空格
for ( ; fast < len; fast++) {
if (fast - 1 > 0 && str[fast] == str[fast - 1] && str[fast] == ' ') {
continue;
} else {
str[slow++] = str[fast];
}
}
// 去掉后面的空格
if (slow - 1 > 0 && str[slow - 1] == ' ') {
str.resize(slow - 1);
} else {
str.resize(slow);
}
}
步骤二:步骤二:反转整个字符串
不必多言
// 反转字符串
void reverseStr(string& str, int start, int end) {
for (int i = start, j = end; i < j; i++, j--) {
swap(str[i], str[j]);
}
}
步骤三:反转字符串里面的单词
定义两个指针,开始遍历字符串,当第二个指针是空格时停止,两个指针的范围的就是单词,反转单词即可
for (int i = 0; i < s.length(); i++) {
int j = i;
while (j < s.length() && s[j] != ' ') {
j++;
}
// 反转
reverseStr(s, i, j - 1);
i = j;
}
完整代码
class Solution {
public:
// 删除空格
void removeSpace(string& str) {
int slow = 0, fast = 0, len = str.length();
// 去掉前面的空格
while (len > 0 && fast < len && str[fast] == ' ') {
fast++;
}
// 去掉中间的空格
for ( ; fast < len; fast++) {
if (fast - 1 > 0 && str[fast] == str[fast - 1] && str[fast] == ' ') {
continue;
} else {
str[slow++] = str[fast];
}
}
// 去掉后面的空格
if (slow - 1 > 0 && str[slow - 1] == ' ') {
str.resize(slow - 1);
} else {
str.resize(slow);
}
}
// 反转字符串
void reverseStr(string& str, int start, int end) {
for (int i = start, j = end; i < j; i++, j--) {
swap(str[i], str[j]);
}
}
string reverseWords(string s) {
removeSpace(s);
reverseStr(s, 0, s.length() - 1);
for (int i = 0; i < s.length(); i++) {
int j = i;
while (j < s.length() && s[j] != ' ') {
j++;
}
reverseStr(s, i, j - 1);
i = j;
}
return s;
}
};