如下所示:
#待处理列表 A= [1,2,3,4,5] #移动次数 a = 3
右移比较简单
for i in range(a): A.insert(0,A.pop())
左移
for i in range(a): A.insert(len(A),A[0]) A.remove(A[0])
#左移
for i in range(a): b = A.pop(0) A.append(b)
列表双向队列
from collections import deque aa = deque(A) #正数表示向右移动,负数表示向左移动 aa.rotate(8) # aa.rotate(-8) print(aa) # deque([3, 4, 5, 1, 2]) print(list(aa)) # [3, 4, 5, 1, 2]
补充:Python 列表元素循环移位
定义函数,完成如下功能: 有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数。函数包括3个参数,分别是整数列表、数字个数、移动次数。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持免费资源网。如有错误或未考虑完全的地方,望不吝赐教。
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论(0)