python使用deque实现fifo(先进先出)

#2:deque还提供了append 和pop方法,在序列的两端都能以相同的速度执行
#例子2:使用deque实现fifo(先进先出),如下:
from collections import deque
import profile,stat
import sys
qeque=deque()
def add1(data):
    qeque.append(data)
def add2():
    qeque.pop()

big_n=100000
@profile(‘deque‘)
def seq():
    for i in range(big_n):
        add1(i)
    for i in range(big_n/2):
        add2()
    for i in range(big_n):
        add1(i)

l=[]
def add3(data):
    l.append(data)
def data4():
    l.pop(-1)

@profile(‘list‘)
def lse():
    for i in range(big_n):
        add3(i)
    for i in range(big_n/2):
        data4()
    for i in range(big_n):
        add3(i)

print seq(),lse()
print stat[‘deque‘]
print stat[‘list‘]

时间: 2025-01-11 22:14:57

python使用deque实现fifo(先进先出)的相关文章

python collections deque

collections是python的高级容器类库,包含了dict.truple之外的常用容器. 下面介绍常用的deque 1. deque是双端队列,可以从两端塞元素进去,也可以从两端取元素. 2. deque是线程安全的,可以用来做多线程的共享资源,我也是因为这个开始接触duque的 >>> from collections import deque >>> a = [1, 2, 3, 4] 用列表初始化deque >>> deq = deque(

26 python 中deque模块详解

deque模块是python标准库collections中的一项,它提供了两端都可以操作的序列,这意味着,在序列的前后你都可以执行添加或删除操作. 1.创建deque序列: from collections import deque d=deque() 2.deque提供了类似list的操作方法: d=deque() d.append(3) d.append(8) d.append(1) 那么此时 d=deque([3,8,1]),len(d)=3,d[0]=3,d[-1]=1 3.两端都使用p

python的deque(双向)队列详解

首先 python的队列有很多种 Python标准库中包含了四种队列,分别是queue.Queue / asyncio.Queue / multiprocessing.Queue / collections.deque 可见deque是标准库collections中的 这其中最好用的是deque 以下是deque的基本操作: 它的操作很像list 同时 相比于list实现的队列,deque实现拥有更低的时间和空间复杂度.list实现在出队(pop)和插入(insert)时的空间复杂度大约为O(n

队列Queue FIFO先进先出 栈Stack FILO先进后出

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace ConsoleApplication1 { class Program { static void Main(string[] args) { //队列的特点就是先进先出 Queue<string> queue = new Queue<st

python运维开发之路02

年底事多,在公司忙成狗,难得把博客更新了下 本章主要内容是collections模块的介绍(队列,计数器,默认字典,有序字典,可命名元组,以及简单介绍深浅拷贝!) collections模块 collection counter 计数器: counter 是继承字典这个父类的功能,所以很多方法都是从字典那里得来的.它的功能就是计算每个元素出现的次数 >>> import collections >>>ret=collections.Counter("asdfk

&lt;&lt;Python基础教程&gt;&gt;学习笔记 | 第02章 | 列表和数组

第02章: 列表和数组 ------ 在Python中最基本的数据结构是序列,每个元素分配一个序号,即元素的序号,也即索引.注意,需要从0开始,第一位0,第二位为1,依次类推. Python包括: 字符串,列表,元祖,字典 这四种常用数据结构,或者说四种序列,其中元祖为不可变序列. 列表和元祖的主要区别 列表可变,而元祖不可变             >>>list1 = ['Tom',40] 所以元祖: 主要用于存储不变的数据   >>> >>> t

第十章 Python常用标准库使用(必会)

本章涉及标准库: 1.sys 2.os 3.glob 4.math 5.random 6.platform 7.pikle与cPikle 8.subprocess 9.Queue 10.StringIO 11.logging 12.ConfigParser 13.urllib与urllib2 14.json 15.time 16.datetime 10.1 sys 1)sys.argv 命令行参数. argv[0] #代表本身名字 argv[1] #第一个参数 argv[2] #第二个参数 ar

python 进场线程

threading.Event 类 event.isSet():返回event的状态值: event.wait():如果 event.isSet()==False将阻塞线程: event.set(): 设置event的状态值为True,所有阻塞池的线程激活进入就绪状态, 等待操作系统调度: event.clear():恢复event的状态值为False. 线程的一个关键特性是每个线程都是独立运行且状态不可预测.如果程序中的其 他线程需要通过判断某个线程的状态来确定自己下一步的操作,这时线程同步问

Python 单向队列Queue模块详解

单向队列Queue,先进先出 '''A multi-producer, multi-consumer queue.''' try: import threading except ImportError: import dummy_threading as threading from collections import deque from heapq import heappush, heappop from time import monotonic as time __all__ =