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

发布时间 2023-03-24 15:29:13作者: ZDREAMER

题目描述:

字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。

请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。

示例 1:

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

 

示例 2:

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

 

限制:

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

 

算法流程:
1.新建一个 list(Python)、StringBuilder(Java) ,记为 res ;
2.先向 res 添加 “第 n + 1位至末位的字符” ;
3.再向 res 添加 “首位至第 n 位的字符” ;
4.将 res 转化为字符串并返回。


复杂度分析:
时间复杂度 O(N): 线性遍历 s 并添加,使用线性时间;
空间复杂度 O(N): 新建的辅助 res使用 O(N)大小的额外空间。

 

 

 

class Solution{
    public String reverseLeftWords(String s,int n){
        StringBuffer res = new StringBuffer();
        for(int i=n;i<s.length();i++){
            res.append(s.charAt(i));
        }
        for(int i=0;i<n;i++){
            res.append(s.charAt(i));
        }
        return res.toString();
    }
}