详解Python的collections模块中的deque双端队列结构
作者:lucifercn 时间:2021-08-15 19:35:57
deque 是 double-ended queue的缩写,类似于 list,不过提供了在两端插入和删除的操作。
appendleft 在列表左侧插入
popleft 弹出列表左侧的值
extendleft 在左侧扩展
例如:
queue = deque()
# append values to wait for processing
queue.appendleft("first")
queue.appendleft("second")
queue.appendleft("third")
# pop values when ready
process(queue.pop()) # would process "first"
# add values while processing
queue.appendleft("fourth")
# what does the queue look like now?
queue # deque(['fourth', 'third', 'second'])
作为一个双端队列,deque还提供了一些其他的好用方法,比如 rotate 等,下面我们一起来看一下:
填充
deque可以从任意一端填充,在python实现称为“左端”和“右端”。
import collections
d1 = collections.deque()
d1.extend('abcdefg')
print 'extend:', d1
d1.append('h')
print 'append:', d1
d2 = collections.deque()
d2.extendleft(xrange(6))
print 'extendleft', d2
d2.appendleft(6)
print 'appendleft', d2
extendleft()迭代处理其输入,对每个元素完成与appendleft()相同的处理。
extend: deque(['a', 'b', 'c', 'd', 'e', 'f', 'g'])
append: deque(['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'])
extendleft deque([5, 4, 3, 2, 1, 0])
appendleft deque([6, 5, 4, 3, 2, 1, 0])
利用
可以从两端利用deque元素,取决于应用的算法。
import collections
print "From the right:"
d = collections.deque('abcdefg')
while True:
try:
print d.pop(),
except IndexError:
break
print "\nFrom the left:"
d = collections.deque(xrange(6))
while True:
try:
print d.popleft(),
except IndexError:
break
使用pop()可以从deque右端删除一个元素,使用popleft()可以从deque左端删除一个元素。
From the right:
g f e d c b a
From the left:
0 1 2 3 4 5
由于双端队列是线程安全的,可以在不同的线程中同时从两端利用队列的内容。
import collections
import threading
import time
candle = collections.deque(xrange(5))
def burn(direction, nextSource):
while True:
try:
next = nextSource()
except IndexError:
break
else:
print '%8s: %s' % (direction, next)
time.sleep(0.1)
print '%8s done' % direction
return
left = threading.Thread(target=burn, args=('Left', candle.popleft))
right = threading.Thread(target=burn, args=('Right', candle.pop))
left.start()
right.start()
left.join()
right.join()
线程交替处理两端,删除元素,知道这个deque为空。
Left: 0 Right: 4
Right: 3 Left: 1
Right: 2 Left done
Right done
旋转
deque另外一个作用可以按照任意一个方向旋转,而跳过一些元素。
import collections
d = collections.deque(xrange(10))
print 'Normal:', d
d= collections.deque(xrange(10))
d.rotate(2)
print 'Right roration:', d
d = collections.deque(xrange(10))
d.rotate(-2)
print 'Left roration:', d
结果:
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 sys
import time
from collections import deque
fancy_loading = deque('>--------------------')
while True:
print '\r%s' % ''.join(fancy_loading),
fancy_loading.rotate(1)
sys.stdout.flush()
time.sleep(0.08)
输出结果:
# 一个无尽循环的跑马灯
------------->-------
标签:Python,deque
0
投稿
猜你喜欢
python定义具名元组实例操作
2023-05-16 22:22:55
浅谈Python中的闭包
2022-03-08 06:18:31
使用python把xmind转换成excel测试用例的实现代码
2022-12-21 06:21:34
python判断所输入的任意一个正整数是否为素数的两种方法
2022-02-26 12:43:14
mysql的case when字段为空,null的问题
2024-01-13 14:40:59
宝塔面板成功部署Django项目流程(图文)
2022-07-29 13:11:19
Python基于hashlib模块的文件MD5一致性加密验证示例
2022-03-30 12:05:40
python使用yield压平嵌套字典的超简单方法
2023-08-28 03:20:00
使用python连接mysql数据库之pymysql模块的使用
2024-01-16 13:12:11
Python pandas中apply函数简介以及用法详解
2022-05-11 03:44:47
Flask框架使用DBUtils模块连接数据库操作示例
2024-01-26 11:46:10
Laravel使用Queue队列的技巧汇总
2024-06-05 09:46:03
迎来2009年CSS裸奔节(CSS Naked Day )
2009-04-24 12:41:00
如何用python插入独创性声明
2021-05-07 04:24:15
Python3.7安装keras和TensorFlow的教程图解
2022-09-05 13:23:00
谈谈图片如何影响转换率
2011-08-10 19:14:08
debug case: onsubmit=return false依然能提交
2009-01-18 13:07:00
python 调用有道api接口的方法
2021-11-18 18:51:16
Python实现动态添加类的属性或成员函数的解决方法
2021-05-13 17:13:41
Python解析json文件相关知识学习
2022-04-01 12:58:19