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

题目

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

方法一:切片
class Solution(object):
    def reverseLeftWords(self, s, n):
        result = s[n:] + s[0:n]
        return result
方法二:翻转

翻转区间为 [0:n) 的子字符串,翻转区间为 [n: ] 的子字符串,翻转整个字符串

class Solution(object):
    def reverseLeftWords(self, s, n):
        s = list(s)
        s[0:n] = list(reversed(s[0:n]))
        s[n: ] = list(reversed(s[n: ]))
        s.reverse()
        return ''.join(s)
参考

代码相关:https://programmercarl.com/%E5%89%91%E6%8C%87Offer58-II.%E5%B7%A6%E6%97%8B%E8%BD%AC%E5%AD%97%E7%AC%A6%E4%B8%B2.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容