微信公众号:路人zhang
扫码关注微信公众号

回复“面试手册”,获取本站PDF版

回复“简历”,获取高质量简历模板

回复“加群”,加入程序员交流群

回复“电子书”,获取程序员类电子书

当前位置: 算法 > 剑指offer > 剑指offer 58-2.左旋转字符串

题目描述

字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串”abcdefg”和数字2,该函数将返回左旋转两位得到的结果”cdefgab”。

示例 1:

输入: s = "abcdefg", k = 2
输出: "cdefgab"

示例 2:

输入: s = "lrloseumgh", k = 6
输出: "umghlrlose"

限制:

  • 1 <= k < s.length <= 10000

算法

(模拟) O(n)

  1. 先翻转要左旋的部分(前一部分 [0, n – 1])
  2. 再翻转剩下的部分(后一部分 [n, end])
  3. 最后将整个字符串翻转

时间复杂度

整个字符串需要被翻转两次(整体翻转、翻转前一部分和后一部分),每次翻转的时间复杂度为 O(n),所以总的时间复杂度为 O(n)

空间复杂度

O(1)

C++ 代码

class Solution {
public:
    string reverseLeftWords(string s, int n) {
        reverse(s.begin(), s.end());
        reverse(s.begin(), s.begin() + s.size() - n);
        reverse(s.begin() + s.size() - n, s.end());
        return s;
    }
};

Java 代码

class Solution {
    public String reverseLeftWords(String s, int n) {
        char[] sArray = s.toCharArray();
        reverse(sArray, 0, sArray.length - 1);
        reverse(sArray, 0, sArray.length - n - 1);
        reverse(sArray, sArray.length - n, sArray.length - 1);
        return new String(sArray);
    }
    
    private void reverse(char[] arr, int left, int right) {
        while (left < right) {
            char temp = arr[left];
            arr[left] = arr[right];
            arr[right] = temp;
            left++;
            right--;
        }
    }
}

Python 代码

class Solution:
    def reverseLeftWords(self, s: str, n: int) -> str:
        s_list = list(s)
        s_list.reverse()
        s_list[:s_list.__len__() - n] = reversed(s_list[:s_list.__len__() - n])
        s_list[s_list.__len__() - n:] = reversed(s_list[s_list.__len__() - n:])
        return ''.join(s_list)

本文由读者提供Github地址:https://github.com/tonngw


点击面试手册,获取本站面试手册PDF完整版