热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python数据结构算法(03)栈队列

Python数据结构&算法(03)栈和队列文章目录Python数据结构&算法(03)栈和队列3.1栈3.1.1栈的基本操作3.1.2链式栈3.2队列3.2.1队列的基本操作3.2.

Python数据结构&算法(03) 栈和队列


文章目录

  • Python数据结构&算法(03) 栈和队列
    • 3.1 栈
      • 3.1.1 栈的基本操作
      • 3.1.2 链式栈
    • 3.2 队列
      • 3.2.1 队列的基本操作
      • 3.2.2 链式队列
      • 3.3.3 循环队列


3.1 栈

可以理解为只允许在表尾进行插入或删除的线性表,对栈而言,其表尾称为栈顶,相应的其表头端称为栈底,不含元素的空表称为空栈。

假设栈 S = (a1, a2, ..., an) ,则称 a1 为栈底元素,an 为栈顶元素。栈中元素是按照 a1, a2, ..., an 的顺序依次进栈的,退栈的第一个元素应为栈顶元素,因此栈可以被称为 后进先出(LIFO) 结构的线性表。

在这里插入图片描述


3.1.1 栈的基本操作

栈的抽象数据类型定义如下所示:

ADT Stack{数据对象:D = {ai | ai ∈ ElemSet, i = 1, 2, ..., n, n >= 0}数据关系:R = { | ai-1, ai ∈ D, i = 2, ..., n}约定 an 为栈顶,a1 为栈底。基本操作:初始化栈插入元素删除元素清空栈判断栈是否为空返回栈中元素个数返回栈顶元素的值遍历栈
}

在python中,列表很好的实现了栈的功能,使用相关函数即可实现出栈和入栈的操作。

list.append() # 将元素添加至末尾list.pop([index=-1]) # 删除指定位置的元素,若为空则删除末尾元素

3.1.2 链式栈

如果使用链表实现栈则可以使用尾插法模拟入栈操作,指定删除最后一个元素即可实现出栈操作。

class Node:def __init__(self, elem=None):self.elem = elemself.next = Noneclass Stack:def __init__(self):self.__base = Node(-1)self.__top = self.__basedef push(self, elem):newNode = Node(elem)self.__top.next = newNodeself.__top = newNodedef pop(self):if self.__base.next == None:print("Error!")return 0else:nowNode = self.__basewhile nowNode.next.next != None:nowNode = nowNode.nextnowNode.next = Noneself.__top = nowNodedef clear(self):self.__base.next = Noneself.__top = self.__basedef isEmpty(self):return self.__base.elem == self.__top.elemdef num(self):num = 0nowNode = self.__basewhile nowNode.next != None:nowNode = nowNode.nextnum = num + 1return numdef getTop(self):return self.__top.elemdef printStack(self):nowNode = self.__base.nextwhile nowNode != None:print(nowNode.elem)nowNode = nowNode.nextif __name__ == "__main__":S = Stack()for i in range(1, 10):S.push(i)S.printStack()

3.2 队列

队列与栈相反,是一种先进先出(FIFO)的线性表,它只允许在表的一端进行插入,而在另一端删除元素。在队列中,允许插入的一端叫做队尾,允许删除的一端叫做队头

在这里插入图片描述


3.2.1 队列的基本操作

队列的操作与栈的操作类似,不同之处在于删除是在表的头部(队头)进行的。

ADT Queue{数据对象:D = {ai | ai ∈ ElemSet, i = 1, 2, ..., n, n >= 0}数据关系:R = { | ai-1, ai ∈ D, i = 2, ..., n}基本操作:初始化队列插入元素删除元素清空队列判断队列是否为空返回队列中元素个数返回队头元素的值遍历队列
}

3.2.2 链式队列

用链表表示的队列简称为链队列,一个链队列需要两个分别指示队头和队尾的指针。

class Node:def __init__(self, elem=None):self.elem = elemself.next = Noneclass Queue:def __init__(self):self.__front = Node(-1)self.__rear = self.__frontdef enQueue(self, elem):newNode = Node(elem)self.__rear.next = newNodeself.__rear = newNodedef deQueue(self):if self.__front.next == None:print("Error!")return 0else:self.__front.next = self.__front.next.nextdef clear(self):self.__front.next = Noneself.__rear = self.__frontdef isEmpty(self):return self.__front == self.__reardef num(self):num = 0nowNode = self.__frontwhile nowNode.next != None:nowNode = nowNode.nextnum = num + 1return numdef getHead(self):if self.__front.next == None:print("Error!")return 0else:return self.__front.next.elemdef printQueue(self):nowNode = self.__front.nextwhile nowNode != None:print(nowNode.elem)nowNode = nowNode.nextif __name__ == "__main__":Q = Queue()for i in range(1, 10):Q.enQueue(i)Q.printQueue()

3.3.3 循环队列

循环队列需要给队列指定一个最大长度,整体逻辑结构如同一个环,这里实现采用顺序表示(用一组地址连续的存储单元依次存储元素)。

在这里插入图片描述

class CircularQueue:def __init__(self, maxSize):self.queue = [None] * maxSizeself.maxSize = maxSizeself.__front = 0self.__rear = 0def num(self):if self.queue[self.__rear] == None:return (self.__rear - self.__front + self.maxSize) % self.maxSizeelse:return self.maxSizedef enQueue(self, elem):if (self.__rear + 1) % self.maxSize == self.__front:if self.queue[self.__rear] == None:self.queue[self.__rear] = elemelse:print("FULL QUEUE!")else:self.queue[self.__rear] = elemself.__rear = (self.__rear + 1) % self.maxSizedef deQueue(self):if self.__front == self.__rear:print("EMPTY QUEUE!")return 0else:self.queue[self.__front] = Noneif (self.__rear + 1) % self.maxSize == self.__front:self.__rear = (self.__rear + 1) % self.maxSizeself.__front = (self.__front + 1) % self.maxSizedef printCircularQueue(self):for i in range(self.maxSize):print(self.queue[i])if __name__ == "__main__":CQ = CircularQueue(9)for i in range(1, 10):CQ.enQueue(i)CQ.printCircularQueue()

推荐阅读
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • 毕业设计:基于机器学习与深度学习的垃圾邮件(短信)分类算法实现
    本文详细介绍了如何使用机器学习和深度学习技术对垃圾邮件和短信进行分类。内容涵盖从数据集介绍、预处理、特征提取到模型训练与评估的完整流程,并提供了具体的代码示例和实验结果。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 本文深入探讨了 Python 列表切片的基本概念和实际应用,通过具体示例展示了不同切片方式的使用方法及其背后的逻辑。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文提供了使用Java实现Bellman-Ford算法解决POJ 3259问题的代码示例,详细解释了如何通过该算法检测负权环来判断时间旅行的可能性。 ... [详细]
  • 最近团队在部署DLP,作为一个技术人员对于黑盒看不到的地方还是充满了好奇心。多次咨询乙方人员DLP的算法原理是什么,他们都以商业秘密为由避而不谈,不得已只能自己查资料学习,于是有了下面的浅见。身为甲方,虽然不需要开发DLP产品,但是也有必要弄明白DLP基本的原理。俗话说工欲善其事必先利其器,只有在懂这个工具的原理之后才能更加灵活地使用这个工具,即使出现意外情况也能快速排错,越接近底层,越接近真相。根据DLP的实际用途,本文将DLP检测分为2部分,泄露关键字检测和近似重复文档检测。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文深入探讨了 Python 中的循环结构(包括 for 循环和 while 循环)、函数定义与调用,以及面向对象编程的基础概念。通过详细解释和代码示例,帮助读者更好地理解和应用这些核心编程元素。 ... [详细]
  • 本文探讨了在Java中实现系统托盘最小化的两种方法:使用SWT库和JDK6自带的功能。通过这两种方式,开发者可以创建跨平台的应用程序,使窗口能够最小化到系统托盘,并提供丰富的交互功能。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 本文探讨了 C++ 中普通数组和标准库类型 vector 的初始化方法。普通数组具有固定长度,而 vector 是一种可扩展的容器,允许动态调整大小。文章详细介绍了不同初始化方式及其应用场景,并提供了代码示例以加深理解。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 本文深入探讨了POJ2762问题,旨在通过强连通分量缩点和单向连通性的判断方法,解决有向图中任意两点之间的可达性问题。文章详细介绍了算法原理、实现步骤,并附带完整的代码示例。 ... [详细]
author-avatar
踏山321
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有