详解Python的collections模块中的deque双端队列结构


Posted in Python onJuly 07, 2016

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
print "\nFrom the left:"
d = collections.deque(xrange(6))
while True:
 try:
  print d.popleft(),
 except IndexError:
  break
print

使用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 相关文章推荐
用Python给文本创立向量空间模型的教程
Apr 23 Python
详解Python的Django框架中Manager方法的使用
Jul 21 Python
Django Admin实现上传图片校验功能
Mar 06 Python
浅谈python中scipy.misc.logsumexp函数的运用场景
Jun 23 Python
Python实现字符串逆序输出功能示例
Jun 24 Python
在cmd中运行.py文件: python的操作步骤
May 12 Python
python找出因数与质因数的方法
Jul 25 Python
python requests模拟登陆github的实现方法
Dec 26 Python
python 计算概率密度、累计分布、逆函数的例子
Feb 25 Python
Django+Celery实现动态配置定时任务的方法示例
May 26 Python
Pyside2中嵌入Matplotlib的绘图的实现
Feb 22 Python
python运行脚本文件的三种方法实例
Jun 25 Python
简单掌握Python的Collections模块中counter结构的用法
Jul 07 #Python
Python处理json字符串转化为字典的简单实现
Jul 07 #Python
全面了解python字符串和字典
Jul 07 #Python
对于Python中RawString的理解介绍
Jul 07 #Python
python变量不能以数字打头详解
Jul 06 #Python
Python中shutil模块的常用文件操作函数用法示例
Jul 05 #Python
详解Python中的array数组模块相关使用
Jul 05 #Python
You might like
利用yahoo汇率接口实现实时汇率转换示例 汇率转换器
2014/01/14 PHP
PHP7内核CGI与FastCGI详解
2019/04/14 PHP
利用PHP内置SERVER开启web服务(本地开发使用)
2021/03/09 PHP
setAttribute 与 class冲突解决
2008/02/17 Javascript
javascript 命名空间以提高代码重用性
2008/11/13 Javascript
javascript笔记 String类replace函数的一些事
2011/09/22 Javascript
使用GruntJS链接与压缩多个JavaScript文件过程详解
2013/08/02 Javascript
深入探密Javascript数组方法
2015/01/08 Javascript
限制上传文件大小和格式的jQuery插件实例
2015/01/24 Javascript
深入理解JavaScript系列(34):设计模式之命令模式详解
2015/03/03 Javascript
JS实现的数组全排列输出算法
2015/03/19 Javascript
详解JS中的立即执行函数
2017/02/24 Javascript
如何使用JS在HTML中自定义字符串格式化
2017/07/20 Javascript
详解vue渲染函数render的使用
2017/12/12 Javascript
vue封装可复用组件confirm,并绑定在vue原型上的示例
2019/10/31 Javascript
Vue打包后访问静态资源路径问题
2019/11/08 Javascript
Angular8引入百度Echarts进行图表分析的实现代码
2019/11/27 Javascript
如何在vue中使用HTML 5 拖放API
2021/01/14 Vue.js
python检测某个变量是否有定义的方法
2015/05/20 Python
深入解析Python中的list列表及其切片和迭代操作
2016/03/13 Python
Python实现通过继承覆盖方法示例
2018/07/02 Python
python3.4控制用户输入与输出的方法
2018/10/17 Python
python实现动态创建类的方法分析
2019/06/25 Python
django云端留言板实例详解
2019/07/22 Python
Python 通过截图匹配原图中的位置(opencv)实例
2019/08/27 Python
Python实现手势识别
2020/10/21 Python
捷克家居装饰及图书音像购物网站:Velký košík
2018/04/16 全球购物
印尼购物网站:iLOTTE
2019/10/16 全球购物
俄罗斯购买剧院和演唱会门票网站:Parter.ru
2019/11/09 全球购物
异常和异常类的概念
2014/09/12 面试题
资产评估专业大学生求职信
2013/09/29 职场文书
逃课上网检讨书
2014/02/20 职场文书
手机被没收检讨书
2014/02/22 职场文书
调查研究项目计划书
2014/04/29 职场文书
格列夫游记读书笔记
2015/07/01 职场文书
2016银行求职自荐信
2016/01/28 职场文书