剑指offer 43. 左旋转字符串

左旋转字符串

http://www.nowcoder.com/questionTerminal/12d959b108cb42b1ab72cef4d36af5ec

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
全部评论

相关推荐

渐好:软光栅真的写明白了吗,既然是软渲那技术栈不应该使用OpenGL,光追和bvh既不算什么高级渲染技术更不应该属于软渲的内容,git那个项目没啥用,建议把前两个项目重新组织一下语言,比如软渲染那个项目 冯着色和msaa、贴图这几项分开写,写的到位点,如果你还学过光追那就单独写出来,如果没把握考官问你答不上来就别写给自己找麻烦,在技术栈那一栏简单提一下自己学过就行,这样杂的放在一起不太严谨,个人愚见.
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务