第一种方法:特点是直接、容易理解,缺点是速度慢,只能实现循环左移。
1
2
3
4
5
|
def demo(lst, k):
temp = lst[:]
for i in range(k):
temp.append(temp.pop(0))
return temp
|
第二种方法:特点是速度快,并且自适应循环左移(k>0)和右移(k<0),缺点是涉及到算法,不容易理解。
1
2
3
4
5
6
7
|
def demo(lst, k):
x = lst[:k]
x.reverse()
y = lst[k:]
y.reverse()
r = x+y
return list(reversed(r))
|
最Pythonic的终极方法:使用切片,简单易理解,速度最快,可同时实现循环左移(k>0)和右移(k<0)。
1
2
|
def demo(lst, k):
return lst[k:] + lst[:k]
|
以上这篇Python序列循环移位的3种方法推荐就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/qing101hua/article/details/78405904