时间:2021-05-22
deque 是 double-ended queue的缩写,类似于 list,不过提供了在两端插入和删除的操作。
例如:
queue = deque()# append values to wait for processingqueue.appendleft("first")queue.appendleft("second")queue.appendleft("third")# pop values when readyprocess(queue.pop()) # would process "first"# add values while processingqueue.appendleft("fourth")# what does the queue look like now?queue # deque(['fourth', 'third', 'second'])作为一个双端队列,deque还提供了一些其他的好用方法,比如 rotate 等,下面我们一起来看一下:
填充
deque可以从任意一端填充,在python实现称为“左端”和“右端”。
extendleft()迭代处理其输入,对每个元素完成与appendleft()相同的处理。
利用
可以从两端利用deque元素,取决于应用的算法。
使用pop()可以从deque右端删除一个元素,使用popleft()可以从deque左端删除一个元素。
由于双端队列是线程安全的,可以在不同的线程中同时从两端利用队列的内容。
线程交替处理两端,删除元素,知道这个deque为空。
旋转
deque另外一个作用可以按照任意一个方向旋转,而跳过一些元素。
结果:
Normal: deque([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])Right roration: deque([8, 9, 0, 1, 2, 3, 4, 5, 6, 7])Left roration: deque([2, 3, 4, 5, 6, 7, 8, 9, 0, 1])再举个例子:
# -*- coding: utf-8 -*-"""下面这个是一个有趣的例子,主要使用了deque的rotate方法来实现了一个无限循环的加载动画"""import sysimport timefrom collections import dequefancy_loading = deque('>--------------------')while True: print '\r%s' % ''.join(fancy_loading), fancy_loading.rotate(1) sys.stdout.flush() time.sleep(0.08)输出结果:
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Python实现的数据结构与算法之双端队列。分享给大家供大家参考。具体分析如下:一、概述双端队列(deque,全名double-endedqueu
本文实例讲述了python双端队列原理、实现与使用方法。分享给大家供大家参考,具体如下:双端队列双端队列(deque,全名double-endedqueue),
最近在pythonTip做题的时候,遇到了deque模块,以前对其不太了解,现在特此总结一下deque模块是python标准库collections中的一项,它
很早以前,在学习使用Python的deque容器时,我写了一篇文章python3deque双向队列创建与使用方法分析。最近需要压测线上服务的性能,又不愿意总是在
Python中,队列是线程间最常用的交换数据的形式。PythonQueue模块有三种队列及构造函数:1、PythonQueue模块的FIFO队列先进先出。cla