剑指 Offer 58 - II. 左旋转字符串

189 阅读1分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路。

剑指 Offer 58 - II. 左旋转字符串

QQ截图20220422224006.png

思路:

  • 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]