队列 Python

一、队列的实现

python 复制代码
class Queue:
    def __init__(self):
        self.items = []

    def isEmpty(self):
        return self.items == []

    def enqueue(self, item):
        self.items.insert(0, item)

    def dequeue(self):
        return self.items.pop()

    def size(self):
        return len(self.items)

二、实例问题

1.模拟传土豆

思路:

假设握着土豆的孩子位于队列的头部。在模 拟传土豆的过程中,程序将这个孩子的名字移出队列,然后立刻将其插入队列的尾部。随后,这 个孩子会一直等待,直到再次到达队列的头部。在出列和入列 num 次之后,此时位于队列头部 的孩子出局,新一轮游戏开始。如此反复,直到队列中只剩下一个名字(队列的大小为 1)。

python 复制代码
from main import Queue


def hotPotato(namelist, num):
    simqueue = Queue()
    # 将名字加入到列表中
    for name in namelist:
        simqueue.enqueue(name)

    while simqueue.size() > 1:
        # 实现了一个环,将头部元素出列,再使得该元素入列到尾部
        for i in range(num):
            simqueue.enqueue(simqueue.dequeue())
        simqueue.dequeue()

    return simqueue.dequeue()


result = hotPotato(["Bill", "David", "Susan", "Jane", "Kent", "Brad"], 7)
print(result)

2.模拟打印机(还未看懂--4.20更新)

三、双端队列

1.实现方式

须有的功能

python 复制代码
class Deque:
    def __init__(self):
        self.items = []

    def isEmpty(self):
        return self.items == []

    # 前端添加元素
    def addFront(self, item):
        self.items.append(item)

    # 后端添加元素
    def addRear(self, item):
        self.items.insert(0, item)

    def size(self):
        return len(self.items)

    # 从前端移除一个元素
    def removeFront(self):
        return self.items.pop()

    # 从后端移除一个元素
    def removeRear(self):
        return self.items.pop(0)

2.实际应用

2.1回文检测器

思路:

使用一个双端队列来存储字符串中的字符。按从左往右的顺序将字符 串中的字符添加到双端队列的后端。此时,该双端队列类似于一个普通的队列。然而,可以利 用双端队列的双重性,其前端是字符串的第一个字符,后端是字符串的最后一个字符,两者是否相等

python 复制代码
# class Deque我定义在main.py文件中,用前需导入
from main import Deque


def palchecker(aString):
    '''
    回文检测器
    :param aString: 传入字符串
    :return: bool型数据
    '''
    chardeque = Deque()  # 定义双端队列
    # 从做到用遍历字符串并将其添加到双端队列的后端
    for ch in aString:
        chardeque.addRear(ch)

    stillEqual = True  # 用于判断是否为回文字符串

    while chardeque.size() > 1:
        leftchar = chardeque.removeFront()  # 原先左边字符
        rightchar = chardeque.removeRear()  # 原先右边字符
        if leftchar != rightchar:
            stillEqual = False

    return stillEqual

result = palchecker("palchecker")
print(result)
相关推荐
galaxy_strive2 分钟前
绘制饼图详细过程
开发语言·c++·qt
Mark_Aussie23 分钟前
Flask-SQLAlchemy使用小结
python·flask
程序员阿龙35 分钟前
【精选】计算机毕业设计Python Flask海口天气数据分析可视化系统 气象数据采集处理 天气趋势图表展示 数据可视化平台源码+论文+PPT+讲解
python·flask·课程设计·数据可视化系统·天气数据分析·海口气象数据·pandas 数据处理
ZHOU_WUYI41 分钟前
Flask与Celery 项目应用(shared_task使用)
后端·python·flask
黑客老李1 小时前
JavaSec | SpringAOP 链学习分析
java·运维·服务器·开发语言·学习·apache·memcached
开开心心就好1 小时前
高效Excel合并拆分软件
开发语言·javascript·c#·ocr·排序算法·excel·最小二乘法
且慢.5891 小时前
Python_day47
python·深度学习·计算机视觉
特立独行的猫a1 小时前
Nuxt.js 中的路由配置详解
开发语言·前端·javascript·路由·nuxt·nuxtjs
佩奇的技术笔记1 小时前
Python入门手册:异常处理
python
勤奋的知更鸟1 小时前
Java编程之原型模式
java·开发语言·原型模式