IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> Python实现队列双端队列 -> 正文阅读

[Python知识库]Python实现队列双端队列

1.队列

队列是元素的有序集合,在尾部添加元素,头部移除元素(类似于排队)

2.队列特性

先进先出(FIFO,first?in?first out)

3.队列抽象数据类型

? ? ? ? Queue():创建一个空队列,不需要参数,返回一个空队列

? ? ? ? enqueue(item):在队列尾部添加一个元素,需要一个元素作为参数,不返回任何值

? ? ? ? dequeue():从队列头部移除一个元素,不需要参数,返回一个元素,且修改队列的内容

? ? ? ? isEmpty():检查队列是否为空,不需要参数,返回一个布尔值

? ? ? ? size():返回队列中元素的数目,不需要参数,且会返回一个整数

?4.用python列表实现队列

#将列表的0索引位置作为队列的尾部
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)

q = Queue()
print(q.isEmpty())
q.enqueue([1,2,3,"jq",True])
print(q.isEmpty())
print(q.dequeue())
q.enqueue(999)
q.enqueue(888)
print(q.dequeue())
print(q.size())

?5.双端队列Deque

双端队列有前后两端,其两端都可以添加或删除元素,不受限制,具体的使用原则取决于使用者

6.双端队列抽象数据类型

? ? ? ? Deque:创建一个空的双端队列,不需要参数,返回一个空的双端队列

? ? ? ? addFront(item):在双端队列前端添加一个元素,接收一个元素作为参数,无返回值

? ? ? ? addRear(item):在双端队列后端添加一个元素,接收一个元素作为参数,无返回值

? ? ? ? removeFront():移除双端队列前端一个元素,不需要参数,且会返回一个元素,并修改双端队列内容

? ? ? ? removeRear():移除双端队列后端一个元素,不需要参数,且会返回一个元素,并修改双端队列内容

? ? ? ? isEmpty():判断双端队列是否为空,不需要参数,且会返回一个布尔值

? ? ? ? size():返回双端队列元素个数,不需要参数,且会返回一个整数

?7.用python列表实现双端队列

#把列表索引0位置作为双端队列后端
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 removeFront(self):
        return self.items.pop()
    def removeRear(self):
        return self.items.pop(0)
    def size(self):
        return len(self.items)

de = Deque()
print(de.isEmpty())
de.addFront(1)
de.addRear(2)
print(de.size())
de.removeFront()
de.removeRear()
print(de.size())

8.用双端队列实现回文检测

from Algorithm import Deque

def palchecker(aString):
    """
    用双端队列实现回文检测
    :param aString: 输入字符串
    :return: 布尔值
    """
    chardeque = Deque.Deque()
    for ch in aString:
        chardeque.addRear(ch)
    stillEqual = True
    while chardeque.size()>1 and stillEqual:
        first = chardeque.removeFront()
        last = chardeque.removeRear()
        if first != last:
            stillEqual = False
    return stillEqual

print(palchecker("python"))
print(palchecker("madam"))

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-11-30 15:34:38  更:2021-11-30 15:36:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 18:45:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码