首页 > 编程语言 >Python中提供的各种队列结构

Python中提供的各种队列结构

时间:2023-06-09 21:05:25浏览次数:47  
标签:11 deque maxlen Python 10 队列 put 结构


Python标准库queue提供了LILO队列类Queue、LIFO队列类LifoQueue、优先级队列类PriorityQueue,标准库collections提供了双端队列。例如:

>>> from queue import Queue #LILO队列
>>> q = Queue()   #创建队列对象
>>> q.put(0)  #在队列尾部插入元素
>>> q.put(1)
>>> q.put(2)
>>> print(q.queue) #查看队列中所有元素
deque([0, 1, 2])
>>> q.get()   #返回并删除队列头部元素
0
>>> q.get()
1
>>> q.queue
deque([2])
>>> q.get()
2
>>> from queue import LifoQueue #LIFO队列
>>> q = LifoQueue()   #创建LIFO队列对象
>>> q.put(1)  #在队列尾部插入元素
>>> q.put(2)
>>> q.put(3)
>>> q.queue  #查看队列中所有元素
[1, 2, 3]
>>> q.get()   #返回并删除队列尾部元素
3
>>> q.queue
[1, 2]
>>> q.get()
2
>>> q.queue
[1]
>>> from queue import PriorityQueue   #优先级队列
>>> q = PriorityQueue()  #创建优先级队列对象
>>> q.put(3)   #插入元素
>>> q.put(8)
>>> q.put(100)
>>> q.queue   #查看优先级队列中所有元素
[3, 8, 100]
>>> q.put(1)   #插入元素,自动调整优先级队列
>>> q.put(2)
>>> q.queue
[1, 2, 100, 8, 3]
>>> q.get() #返回并删除优先级最低的元素
1
>>> q.get() #请多执行几次该语句并观察返回的数据
2
>>> from collections import deque
>>> q = deque(maxlen=5) #创建双端队列
>>> for item in [3, 5, 7, 9, 11]:  #添加元素
 q.append(item)
>>> q.append(13)   #队列满,自动溢出
>>> q
deque([5, 7, 9, 11, 13], maxlen=5)
>>> q.append(15)
>>> q
deque([7, 9, 11, 13, 15], maxlen=5)
>>> q.appendleft(5)   #从左侧添加元素,右侧自动溢出
>>> q
deque([5, 7, 9, 11, 13], maxlen=5)
>>> q.popleft()   #弹出并返回最左端元素
5
>>> q
deque([7, 9, 11, 13], maxlen=5)
>>> q.pop()  #弹出并返回最右端元素
13
>>> q
deque([7, 9, 11], maxlen=5)
>>> q.insert(2,10) #在中间位置插入元素
>>> q
deque([7, 9, 10, 11], maxlen=5)
>>> q
deque([7, 9, 10, 11], maxlen=5)
>>> q += [1, 2] #追加多个元素
>>> q
deque([9, 10, 11, 1, 2], maxlen=5)
>>> q.pop()
2
>>> q.pop()
1
>>> q
deque([9, 10, 11], maxlen=5)
>>> q *= 2   #序列重复
>>> q
deque([10, 11, 9, 10, 11], maxlen=5)
>>> q.count(10)  #返回元素出现次数
2
>>> q.rotate(2)   #循环右移2个元素
>>> q
deque([10, 11, 10, 11, 9], maxlen=5)
>>> q.rotate(-2)  #循环左移2个元素
>>> q
deque([10, 11, 9, 10, 11], maxlen=5)

标签:11,deque,maxlen,Python,10,队列,put,结构
From: https://blog.51cto.com/u_9653244/6451069

相关文章

  • Python编写编程作业批量自动打分程序的思路与实现
    总体思路:把接口明确地告诉学生(本文后面的代码要求学生程序中必须有个函数叫做searchOnede),然后学生把Python程序文件(学号_姓名.py)以任何方式提交给老师,放到同一文件夹中。下面的代码首先由老师编写一个自己认为的最佳和最优实现,然后把学生的程序文件作为模块导入并调用其中的searchO......
  • 详解Python中的位运算符规则、原理与用法
    在Python中,位运算符包括位与(&)、位或(|)、位求反(~)、位异或(^)、左移位(<<)和右移位(>>)。1.运算方法与规则位运算符只能适用于整数,其总体运算规则为:首先把整数转换为二进制表示形式,按最低位对齐,短的高位补0,然后进行位运算,最后把得到的二进制转换为十进制数。位与运算符运算规则:0&0=0&1=1&0=......
  • Python批量Excel文件数据导入SQLite数据库的优化方案
    说明:1)需要安装扩展库openpyxl;2)随着数据库的增大,导入速度可能会有所下降;3)本文只考虑Python代码优化,没有涉及数据库的优化;4)本文要点在于使用executemany实现批量数据导入,通过减少事务提交次数提高导入速度。fromrandomimportchoice,randrangefromstringimportdigits,ascii......
  • Python求解进制问题(阿里巴巴2015笔试题)
    问题描述:用十进制计算30的阶乘,然后把结果转换成三进制表示,那么该进制表示的结果末尾会有多少个连续0?解析:作为笔试题的话,要想按照题意先把阶乘结果计算出来再转换成三进制最后再数0的个数,时间肯定来不及。也就是说,应该是有更简单的方法。以我们最熟悉的十进制为例,一个数乘以10相当于......
  • Python中直接查看对象值和使用print()输出的区别
    直接用代码来描述这个问题的现象:>>>x=r'C:\windows\notepad.exe'>>>x'C:\\windows\\notepad.exe'>>>print(x)C:\windows\notepad.exe>>>x='''Tomsaid,"Let'sgo."'......
  • Python提取彩色图像的二值化边缘
    所谓二值化是指只包含白和黑这两种颜色,下面的代码中使用白色表示内部或背景,使用黑色表示边缘。图像边缘提取的基本思路是:如果一个像素的颜色值与周围像素足够接近(属于低频部分)则认为是图像背景或者内部,如果一个像素的颜色值与周围像素相差很大(属于高频部分)则认为是图像边缘。在具体......
  • Python+SQLite开发无界面版通信录管理系统
    本文重点在于演示Python对SQLite数据库的操作,以及命令行式菜单的工作原理和实现。首先使用SQLiteDatabaseBrowser创建SQLite数据库data.db,然后创建一个数据表addressList,最后在数据表addressList中创建字段id(INTEGERPRIMARYKEY类型)、name(TEXT类型)、sex(TEXT类型)、age(NUMERIC类型......
  • 妙用Python集合求解啤酒问题(携程2016笔试题)
    问题描述:一位酒商共有5桶葡萄酒和1桶啤酒,6个桶的容量分别为30升、32升、36升、38升、40升和62升,并且只卖整桶酒,不零卖。第一位顾客买走了2整桶葡萄酒,第二位顾客买走的葡萄酒是第一位顾客的2倍。那么,本来有多少升啤酒呢?解析:由于该酒商只卖整桶酒,简单分析几个桶的容量可知,第二位顾客......
  • Python两种方法求解登楼梯问题(京东2016笔试题)
    问题:假设一段楼梯共15个台阶,小明一步最多能上3个台阶,那么小明上这段楼梯一共有多少种方法?解析:从第15个台阶上往回看,有3种方法可以上来(从第14个台阶上一步迈1个台阶上来,从第13个台阶上一步迈2个台阶上来,从第12个台阶上一步迈3个台阶上来),同理,第14个、13个、12个台阶都可以这样推算,从......
  • 大数据分析python
    #导库importnumpyasnpimportpandasaspd#读取数据data=pd.read_csv('logistics.csv')data.head(10)思路:直接查看不同公司的数量即可df1=data.groupby('货运公司名称').size().reset_index(name='count')#直接对货运公司的名称做统计(示例:天天速递25)df12.接通知对......