58 - II. 左旋转字符串 (难度 简单)
字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。
示例 1:
输入: s = “abcdefg”, k = 2
输出: “cdefgab”
示例 2:
输入: s = “lrloseumgh”, k = 6
输出: “umghlrlose”
限制:
1 <= k < s.length <= 10000
题解
一行代码搞定还是挺爽的
class Solution:
def reverseLeftWords(self, s: str, n: int) -> str:
return s[n:]+s[:n]
和上题类似的解决方法,我是先整体反转+局部反转,其实也可以局部+整体反转 反正都行
class Solution:
def revers(self,l,start,end):
while start<end:
l[start],l[end]=l[end],l[start]
start+=1
end-=1
return None
def reverseLeftWords(self, s: str, n: int) -> str:
l=list(s)
self.revers(l,0,len(l)-1)
self.revers(l,0,len(l)-1-n)
self.revers(l,len(l)-n,len(l)-1)
return ''.join(l)