国产成人AV无码一二三区,少女1到100集,国产精品久久久久精品综合紧,巜公妇之诱感肉欲HD在线播放

文章 > 头条 > 一文了解Python collections模块中的deque用法

一文了解Python collections模块中的deque用法

头像

爱喝马黛茶的安东尼

2019-12-03 17:51:283498浏览 · 0收藏 · 0评论


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'])

应用

1、可以使用 deque 的旋转来制作跑马灯:

import collections
import sys
import time
def marquee(length=50, speed=1, direction=1):
    """
    生成一个简单的跑马灯
    length:总长
    speed:每0.1秒的移动速度
    direction:0为向左,1为向右
    """
    if direction == 1:
        array = '>'
    else:
        array = '<'
    que = collections.deque([array])
    que.extend(['-'] * (length - 1)) # 形如'>------'
    while True:
        print('%s' % ''.join(que))
        if direction == 1:
            que.rotate(1 * speed)
        else:
            que.rotate(-1 * speed)
        sys.stdout.flush()
        time.sleep(0.1)
if '__main__' == __name__:
    marquee()

2、可以使用deque的旋转来解决约瑟夫问题:

""" 约瑟夫算法
据说著名犹太历史学家 Josephus 有过以下的故事:
在罗马人占领桥塔帕特后,39个犹太人与 Josephus 及他的朋友躲到一个洞中,
39个犹太人决定宁愿死也不要被敌人抓到,于是决定了一个自杀方式,41个人排成一个圆圈,
由第1个人开始报数,每报数到第3人该人就必须自杀,然后再由下一个重新报数,
直到所有人都自杀身亡为止。然而 Josephus 和他的朋友并不想自杀,
问他俩安排的哪两个位置可以逃过这场死亡游戏?
"""
import collections
def ysf(a, b):
    d = collections.deque(range(1, a+1)) # 将每个人依次编号,放入到队列中
    while d:
        d.rotate(-b) # 队列向左旋转b步
        print(d.pop()) # 将最右边的删除,即自杀的人
if __name__ == '__main__':
    ysf(41,3) # 输出的是自杀的顺序。最后两个是16和31,说明这两个位置可以保证他俩的安全。

3、deque是现成安全的。

import collections
import threading
import time
candle = collections.deque(xrange(10))
print candle
def poper(direction, next_item):
    while True:
        try:
            next = next_item()
        except IndexError:
            break
        else:
            print '%s : %s' % (direction, next)
            time.sleep(0.1)
    print "done %s" % direction
    return
left = threading.Thread(target=poper, args=('left', candle.popleft))
right = threading.Thread(target=poper, args=('right', candle.pop))
left.start()
right.start()
left.join()
right.join()

结果:

deque([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
left : 0
right : 9
right : 8
left : 1
right : 7
left : 2
left : 3
right : 6
left : 4
right : 5
done right
done left

python学习网,免费的在线学习python平台,欢迎关注!

本文转自:https://www.jianshu.com/p/bed1f725dddc

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

性感内衣女装| 夹腿高潮后注意力不集中能恢复吗| 白丝| 玉蒲团之乳欲春宵| 他扒开我小流添我三男一女视频| 《请好好疼爱里面》免费观看| 《甜性涩爱》韩国三级| 《炸裂吧!巨棒》免费阅读漫画| 摸的下身已洪水泛滥怎么办 | 香蕉视频安装包怎么安装| 掀起衣服揉她的奶头| 妈妈和女儿齐上阵的播出时间| 《伦敦空姐美版2023》| 蜜桃成熟时| 床3| 上海吃奶门| 中国高清WINDOWS视频| 黑料| 《囚禁空姐》电影免费观看| 亲爱的爸爸【父女】笔趣阁负责的| 熟母10和熟母10的区别| 女生穿露胸开又裙穿搭大忌| 情趣内衣| 3DMAX9喷射2D3D区别漫.| 《疯狂72小时》韩剧| 黑兽| 妈妈装睡配合孩子阴阳调和 | 大茄子| 老和尚猛挺进她莹莹的体导演是谁| 少女配狗视频大全播放| 尧建云| 女性私密紧致情趣玩具| 欧美多人| 露胸透明睡衣| 小妹妹爱大棒棒免费观看电视剧一 | 小俊在雪姨身上耕耘小说免费阅读| 美女被咬小头头视频大全 | 老头下边又粗又大又硬| 二人生猴子全程免费| 姐妹花破瓜双飞记的寓意和象征意... | 用毛笔刷尿孔不准尿出来怎么办