python实现队列

队列是一种先进先出的数据类型,它的跟踪原理类似于在超市收银处排队,队列里的的第一个人首先接受服务,新的元素通过入队的方式添加到队列的末尾,而出队就是将队列的头元素删除。

我们可以设置一个类,用列表来存放栈中元素的信息,利用列表的append()pop()方法可以实现队列的入队enqueue和出队dequeue的操作,上面栈一个元素每次出去是列表的最后一个,直接用list.pop()出栈,而出队列每次是第一个,所以要用list.pop(0)出队列

代码如下:

class Queue():  
    def __init__(self,size):  
        self.size=size; 
        self.front=-1;  
        self.rear=-1;  
        self.queue=[];
    def enqueue(self,ele):  #入队操作  
        if self.isfull():  
            raise exception("queue is full");
        else:  
            self.queue.append(ele)
            self.rear=self.rear+1
    def dequeue(self):      #出队操作  
        if self.isempty():  
            raise exception("queue is empty")
        else:  
            self.front=self.front+1
            return self.queue[self.front]
    def isfull(self):  
        return self.rear-self.front+1==self.size
    def isempty(self):  
        return self.front==self.rear
       
q=Queue(10);  
for i in range(3):  
    q.enqueue(i)
print q.dequeue()
print q.isempty()

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Python开发植物大战僵尸游戏,详细教程

    一墨编程学习
  • 用python炒股?python除了生孩子还有什么不能的!

    不用深厚的数学功底也不用深厚的金融知识, 本文中也不会引用各种高深的投资模型或数学模型。这不用,那不用的,到底怎么用python炒股?往下看

    一墨编程学习
  • Python实现堆栈

    堆栈是一个后进先出的数据结构,其工作方式就像一堆汽车排队进去一个死胡同里面,最先进去的一定是最后出来。

    一墨编程学习
  • 基于图形项的复杂形状和动画--千足虫

    在本篇中,会看到利用图形项来绘制复杂形状和动画,模拟“千足虫”的运动和消亡过程。程序有一个内部的定时器,在没段时间间隙中,这些千足虫都在不停的移动。如果它们的头...

    用户6021899
  • Python写的俄罗斯方块

    简单瞅了下Tkinter,和Canvas配合在一起,还算是简洁的界面开发API。threading.Thread创建新的线程,其多线程机制也算是方便。

    py3study
  • python pyqt5仿window任务计划程序

    from PyQt5 import QtCore, QtWidgets import sys,os import win32api import win3...

    用户5760343
  • selenium爬取拉勾网python职位信息

    菲宇
  • unslider源码分析

    根据Bootstrap中文网的介绍,Unslider一个超小的 jQuery轮播(slider)插件,参照这个汉化版的介绍页面,这个插件有你需要的优点,但是本...

    用户3579639
  • MJRefresh源码剖析与学习

    建议查看原文:https://www.jianshu.com/p/23c876f8ae39(不定时更新)

    Dwyane
  • pyqt5实现浏览器与下载文件弹框

    本文由腾讯云+社区自动同步,原文地址 https://stackoverflow.club/article/pyqt5_webbrowser_download_...

    羽翰尘

扫码关注云+社区

领取腾讯云代金券