今天,带来字符串相关算法的讲解。文中不足错漏之处望请斧正!
将字符串的顺序倒转。
这道题的反转可以直接调用一个库函数,但是这样做意义不大。
解决思路:从两边向中间,两两交换字符。
class Solution {
public:
void reverseString(vector<char>& s) {
int left = 0, right = s.size() - 1;
while (left < right) swap(s[left++], s[right--]);
}
};
用变量计数到2k时,区间内如果:
[i, i + k]
[i, end()]直接按照转化的题意写出代码即可。
暴力写法:
class Solution {
public:
string reverseStr(string s, int k) {
int count = 0, begin = 0;
for (int i = 0; i < s.size(); ++i) {
++count;
if (count == 2 * k) {
myReverse(begin, begin + k - 1, s); // 每次反转k个, 反转区间: [begin, begin + k - 1]
begin = i + 1;
count = 0;
}
}
if (count < k) myReverse(begin, s.size() - 1, s);
else if (count >= k && count < 2 * k) myReverse(begin, begin + k - 1, s);
return s;
}
private:
void myReverse(int begin, int end, string &s) {
while (begin < end) swap(s[begin++], s[end--]);
}
};
简洁写法:
class Solution {
public:
string reverseStr(string s, int k) {
for (int i = 0; i < s.size(); i += 2 * k) { // i每次递增2k,相当于计数到2k
// 够k个就反转
if (i + k < s.size()) reverse(s.begin() + i, s.begin() + i + k);
// 不够k个就全部反转
else reverse(s.begin() + i, s.end());
}
return s;
}
};
今天的分享就到这里了,感谢您能看到这里。
这里是培根的blog,期待与你共同进步!