详解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 相关文章推荐
Python2.5/2.6实用教程 入门基础篇
Nov 29 Python
Python 时间操作例子和时间格式化参数小结
Apr 24 Python
Python实现的Kmeans++算法实例
Apr 26 Python
Python网络编程中urllib2模块的用法总结
Jul 12 Python
使用Python的Flask框架表单插件Flask-WTF实现Web登录验证
Jul 12 Python
Python 记录日志的灵活性和可配置性介绍
Feb 27 Python
python批量替换多文件字符串问题详解
Apr 22 Python
详解Numpy中的数组拼接、合并操作(concatenate, append, stack, hstack, vstack, r_, c_等)
May 27 Python
解决Tensorboard 不显示计算图graph的问题
Feb 15 Python
将tf.batch_matmul替换成tf.matmul的实现
Jun 18 Python
python tkinter实现连连看游戏
Nov 16 Python
MoviePy简介及Python视频剪辑自动化
Dec 18 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
php中设置多级目录session的问题
2011/08/08 PHP
PHP版网站缓存加快打开速度的方法分享
2012/06/03 PHP
php中有关字符串的4个函数substr、strrchr、strstr、ereg介绍和使用例子
2014/04/24 PHP
PHP date()函数警告: It is not safe to rely on the system解决方法
2014/08/20 PHP
php函数serialize()与unserialize()用法实例
2014/11/06 PHP
php+webSoket实现聊天室示例代码(附源码)
2017/02/17 PHP
Laravel 队列使用的实现
2019/01/08 PHP
JavaScript TO HTML 转换
2006/06/26 Javascript
JavaScript通过元素索引号删除数组中对应元素的方法
2015/03/18 Javascript
jQuery实现悬浮在右上角的网页客服效果代码
2015/10/24 Javascript
浅谈Node 调试工具入门教程
2018/03/20 Javascript
vue-lazyload使用总结(推荐)
2018/11/01 Javascript
VUE接入腾讯验证码功能(滑块验证)备忘
2019/05/07 Javascript
uni-app使用微信小程序云函数的步骤示例
2020/05/22 Javascript
在Python中用get()方法获取字典键值的教程
2015/05/21 Python
Python实现二分查找算法实例
2015/05/26 Python
python数据结构之列表和元组的详解
2017/09/23 Python
Python字典数据对象拆分的简单实现方法
2017/12/05 Python
python3获取当前文件的上一级目录实例
2018/04/26 Python
Python中的函数作用域
2018/05/07 Python
python threading和multiprocessing模块基本用法实例分析
2019/07/25 Python
numpy np.newaxis 的实用分享
2019/11/30 Python
CSS3弹性盒模型开发笔记(一)
2016/04/26 HTML / CSS
Expedia挪威官网:酒店、机票和租车
2018/03/03 全球购物
英国在线照明超市:Castlegate Lights
2019/10/30 全球购物
CSMA/CD介质访问控制协议
2015/11/17 面试题
大学生年度自我鉴定
2013/10/31 职场文书
最新党员的自我评价分享
2013/11/04 职场文书
车贷收入证明范本
2014/01/09 职场文书
中学生国旗下讲话稿
2014/04/26 职场文书
教师群众路线剖析材料
2014/09/29 职场文书
社保代办委托书怎么写
2014/10/06 职场文书
2014年党员个人工作总结
2014/12/02 职场文书
小学生2015教师节演讲稿
2015/03/19 职场文书
公司开业的祝贺语大全(60条)
2019/07/05 职场文书
2019安全宣传标语大全
2019/08/14 职场文书