python collections deque_Python collections.deque

简介:

collections 是 python 内建的一个集合模块,里面封装了许多集合类,其中队列相关的集合只有一个:deque。

deque 是双边队列(double-ended queue),具有队列和栈的性质,在 list 的基础上增加了移动、旋转和增删等。

常用方法:

d = collections.deque([])

d.append('a') # 在最右边添加一个元素,此时 d=deque('a')

d.appendleft('b') # 在最左边添加一个元素,此时 d=deque(['b', 'a'])

d.extend(['c','d']) # 在最右边添加所有元素,此时 d=deque(['b', 'a', 'c', 'd'])

d.extendleft(['e','f']) # 在最左边添加所有元素,此时 d=deque(['f', 'e', 'b', 'a', 'c', 'd'])

d.pop() # 将最右边的元素取出,返回 'd',此时 d=deque(['f', 'e', 'b', 'a', 'c'])

d.popleft() # 将最左边的元素取出,返回 'f',此时 d=deque(['e', 'b', 'a', 'c'])

d.rotate(-2) # 向左旋转两个位置(正数则向右旋转),此时 d=deque(['a', 'c', 'e', 'b'])

d.count('a') # 队列中'a'的个数,返回 1

d.remove('c') # 从队列中将'c'删除,此时 d=deque(['a', 'e', 'b'])

d.reverse() # 将队列倒序,此时 d=deque(['b', 'e', 'a'])

使用deque解决约瑟夫问题:

"""约瑟夫算法

据说著名犹太历史学家 Josephus 有过以下的故事:

在罗马人占领桥塔帕特后,39个犹太人与 Josephus 及他的朋友躲到一个洞中,

39个犹太人决定宁愿死也不要被敌人抓到,于是决定了一个自杀方式,41个人排成一个圆圈,

由第1个人开始报数,每报数到第3人该人就必须自杀,然后再由下一个重新报数,

直到所有人都自杀身亡为止。然而 Josephus 和他的朋友并不想自杀,

问他俩安排的哪两个位置可以逃过这场死亡游戏?"""

importcollectionsdefysf(a, b):

d= collections.deque(range(1, a+1)) #将每个人依次编号,放入到队列中

whiled:

d.rotate(-b) #队列向左旋转b步

print(d.pop()) #将最右边的删除,即自杀的人

if __name__ == '__main__':

ysf(41,3) #输出的是自杀的顺序。最后两个是16和31,说明这两个位置可以保证他俩的安全。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值