• 队列的python实现


    队列(queue),是一种操作受限的线性表。只允许在队列的一端添加元素,在队列的另一端删除元素。能添加元素的一端称为队尾,能删除元素的一端称为队头。

    队列最大的特性是:先进先出(FIFO,first in first out)

    下面为普通队列的python实现:

    #!/usr/bin/env python
    # -*- coding:utf-8 -*-
    __author__ = "hsz"
    
    
    class Queue(object):
        """队列"""
        def __init__(self, maxsize=0):
            """maxsize<=0代表队列不限定大小"""
            self.queue = []
            self.maxsize = maxsize
    
        def is_empty(self):
            return len(self.queue) == 0
    
        def is_full(self):
            if self.maxsize <= 0:
                return False
            else:
                return len(self.queue) == self.maxsize
    
        def enqueue(self, item):
            """入队"""
            if self.is_full():
                raise Exception("Queue is full!")
            else:
                self.queue.append(item)
    
        def dequeue(self):
            """出队"""
            if self.is_empty():
                raise IndexError("Queue is empty!")
            else:
                return self.queue.pop(0)
    
        def size(self):
            return len(self.queue)
    
        def get_front(self):
            """
            返回队头元素
            :return:
            """
            if self.is_empty():
                raise IndexError("Queue is empty!")
            else:
                return self.queue[0]
    
        def get_rear(self):
            """
            返回队尾元素
            :return:
            """
            if self.is_empty():
                raise IndexError("Queue is empty!")
            else:
                return self.queue[-1]
    
        def print_queue(self):
            return self.queue
    
    
    if __name__ == "__main__":
        # 实例化对象队列
        queue = Queue()
        # 入队四个数
        queue.enqueue(1)
        queue.enqueue(2)
        queue.enqueue(3)
        queue.enqueue(4)
        print(queue.queue)       # [1, 2, 3, 4]
        print(queue.is_empty())  # False   队列不为空
        print(queue.is_full())   # False   队列没有到最大元素
        # 出队  先入先出  出的是1 所有剩 [2,3,4]
        queue.dequeue()
        print(queue.queue)
        # 返回队列的元素个数 3
        print(queue.size())
        # 获取队列的头数据  2
        print(queue.get_front())
        # 获取队列的尾数据  4
        print(queue.get_rear())
        # 打印队列所有数据 [2,3,4]
        print(queue.print_queue())

    打印结果为:

    [1, 2, 3, 4]
    False
    False
    [2, 3, 4]
    3
    2
    4
    [2, 3, 4]

    其他类型待续。。。

  • 相关阅读:
    UI- 基础控件零散知识点回归
    UI-定时器与动画使用总结
    IE浏览器url中带中文报错的问题;以及各种兼容以及浏览器问题总结
    java实现判断一个经纬度坐标是否在一个多边形内(经自己亲测)
    高德地图web端笔记;发送http请求的工具类
    高德地图JSapi
    shiro(三),使用第三方jdbcRealm连接数据库操作
    shiro(二)自定义realm,模拟数据库查询验证
    java安全框架shiro(一)
    解决celipse中mybatis使用的时候xml没有提示的问题
  • 原文地址:https://www.cnblogs.com/hszstudypy/p/11734591.html
Copyright © 2020-2023  润新知