# 反转字符串
题目链接🔗
要求原地修改,可以定义两个指针,一个在字符串前面,一个在字符串后面,同时向中间移动并交换两元素。
class Solution { | |
public: | |
void reverseString(vector<char>& s) { | |
int i = 0, j = s.size() - 1; | |
while(i < j) { | |
swap(s[i++], s[j--]); | |
} | |
} | |
}; |
或者使用 reverse 库函数。
# 反转字符串 II
题目链接🔗
当需要固定规律一段一段去处理字符串的时候,要想想在在 for 循环的表达式上做做文章。
在遍历字符串的过程中,只要让,i 每次移动 就可以了,然后判断是否需要有反转的区间。
class Solution { | |
public: | |
string reverseStr(string s, int k) { | |
for (int i = 0; i < s.size(); i += (2 * k)) { | |
// 1. 每隔 2k 个字符的前 k 个字符进行反转 | |
// 2. 剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符 | |
if (i + k <= s.size()) { | |
reverse(s.begin() + i, s.begin() + i + k ); | |
} else { | |
// 3. 剩余字符少于 k 个,则将剩余字符全部反转。 | |
reverse(s.begin() + i, s.end()); | |
} | |
} | |
return s; | |
} | |
}; |
# 替换数字
题目链接🔗
首先扩充字符串为替换成 “numebr” 之后的大小。
然后从后向前替换数字字符,也就是双指针法,过程如下:i 指向新长度的末尾,j 指向旧长度的末尾。
从后向前填充元素,避免了从前向后遍历时,每次添加都要将添加元素之后的元素向后移动的问题。
#include <iostream> | |
using namespace std; | |
int main() { | |
string s; | |
while(cin>>s) { | |
int count = 0; // 统计数字个数 | |
int oldSize = s.size(); | |
for(char c : s) { | |
if(c >= '0' && c <= '9') | |
count++; | |
} | |
// 扩充字符串大小 | |
s.resize(s.size() + count * 5); | |
int newSize = s.size(); | |
for(int i = newSize - 1, j = oldSize - 1; j >= 0; i--, j--) { | |
if (s[j] > '9' || s[j] < '0') { | |
s[i] = s[j]; | |
} | |
else { | |
s[i] = 'r'; | |
s[i - 1] = 'e'; | |
s[i - 2] = 'b'; | |
s[i - 3] = 'm'; | |
s[i - 4] = 'u'; | |
s[i - 5] = 'n'; | |
i -= 5; | |
} | |
} | |
cout << s << endl; | |
} | |
return 0; | |
} |
# 翻转字符串里的单词
题目链接🔗
思路如下:
- 移除多余的空格:快慢指针
- 反转整个字符串
- 反转每个单词
class Solution { | |
public: | |
/* 去除所有空格并在相邻单词之间添加空格,快慢指针。*/ | |
void removeExtraSpaces(string& s) { | |
int slow = 0; | |
for (int i = 0; i < s.size(); ++i) { | |
// 遇到非空格就处理,即删除所有空格。 | |
if (s[i] != ' ') { | |
// 手动控制空格,给单词之间添加空格。 | |
//slow != 0 说明不是第一个单词,需要在单词前添加空格。 | |
if (slow != 0) s[slow++] = ' '; | |
// 补上该单词,遇到空格说明单词结束。 | |
while (i < s.size() && s[i] != ' ') { | |
s[slow++] = s[i++]; | |
} | |
} | |
} | |
s.resize(slow); //slow 的大小即为去除多余空格后的大小。 | |
} | |
string reverseWords(string s) { | |
removeExtraSpaces(s); // 去除多余空格,保证单词之间之只有一个空格,且字符串首尾没空格。 | |
reverse(s.begin(), s.end()); | |
int start = 0; | |
for (int i = 0; i <= s.size(); ++i) { | |
if (i >= s.size() || s[i] == ' ') { // 到达空格或者串尾,说明一个单词结束。进行翻转。 | |
reverse(s.begin()+start, s.begin() + i); // 翻转,区间左闭右开。 | |
start = i + 1; // 更新下一个单词的开始下标 start | |
} | |
} | |
return s; | |
} | |
}; |