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

题目描述

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

示例 1:

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

示例 2:

1
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++ 代码

1
2
3
4
5
6
7
8
9
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;
}
};
Author: tonngw
Link: https://tonngw.com/2022/07/09/剑指 Offer/剑指 Offer 58 - II. 左旋转字符串/
Copyright Notice: All articles in this blog are licensed under CC BY-NC-SA 4.0 unless stating additionally.