本文已参与「新人创作礼」活动,一起开启掘金创作之路。
剑指 Offer 58 - II. 左旋转字符串
- 题号:力扣剑指 Offer 58 - II
- 知识点:字符串,双指针
- 总结 题干:
思路:
- 1.使用快慢指针,先让fast走n步,并记录下前n个字符(也就是左边的n个字符)到left_s中。
- 2.然后快指针和慢指针同时往右移动,将快指针所指的字符放到慢指针所指的位置,实现第n个之后的字符前移n位。
- 3.然后再将left_s中的字符接着慢指针的位置更新到字符串的右边
// C++
class Solution {
public:
string reverseLeftWords(string s, int n) {
int slow = 0;
int fast = 0;
string left_s = "";
while(fast < n){
left_s += s[fast];
fast++;
}
while(fast < s.size()){
s[slow] = s[fast];
fast++;
slow++;
}
for (int i = 0; i<left_s.size(); i++){
s[slow] = left_s[i];
slow++;
}
return s;
}
};
- 4.这是简单的python代码
# python
class Solution:
def reverseLeftWords(self, s: str, n: int) -> str:
return s[n:] + s[:n]