43. 左旋转字符串
题目描述
汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!
思路
思路一:
循环左移,对于空字符串或者位移次数为0时,直接返回原字符串即可,位移次数n的有效位移次数应该是n%len(s),剩下的用字符串的切片即可。但是这种方法引入了新的空间,用了切片就是引入了新的字符串空间。
思路二:
灵活利用字符串翻转
原理:
利用list的翻转,没有引入新的字符串或者数组空间。
代码实现
思路一:
# -*- coding:utf-8 -*- class Solution: def LeftRotateString(self, s, n): # write code here length = len(s) if n == 0 or length <= 1: return s else: n = n % length return s[n:] + s[:n]
思路二:
# -*- coding:utf-8 -*- class Solution: def LeftRotateString(self, s, n): # write code here length = len(s) if n == 0 or length <= 1: return s else: s = list(s) n = n % length self.string_reverse(s,0,n-1) self.string_reverse(s,n,length-1) self.string_reverse(s,0,length-1) return "".join(s) def string_reverse(self,string,start,end): while(start<end): temp = string[start] string[start] = string[end] string[end] = temp start+=1 end-=1