队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。队列中没有元素时,称为空队列。
队列的数据元素又称为队列元素。在队列中插入一个队列元素称为入队,从队列中删除一个队列元素称为出队。因为队列只允许在一端插入,在另一端删除,所以只有最早进入队列的元素才能最先从队列中删除,故队列又称为先进先出(FIFO—first in first out)线性表。 [1]
顺序队列
建立顺序队列结构必须为其静态分配或动态申请一片连续的存储空间,并设置两个指针进行管理。一个是队头指针front,它指向队头元素;另一个是队尾指针rear,它指向下一个入队元素的存储位置,如图所示

每次在队尾插入一个元素是,rear增1;每次在队头删除一个元素时,front增1。随着插入和删除操作的进行,队列元素的个数不断变化,队列所占的存储空间也在为队列结构所分配的连续空间中移动。当front=rear时,队列中没有任何元素,称为空队列。当rear增加到指向分配的连续空间之外时,队列无法再插入新元素,但这时往往还有大量可用空间未被占用,这些空间是已经出队的队列元素曾经占用过得存储单元。
顺序队列中的溢出现象:
(1) "下溢"现象:当队列为空时,做出队运算产生的溢出现象。“下溢”是正常现象,常用作程序控制转移的条件。
(2)"真上溢"现象:当队列满时,做进栈运算产生空间溢出的现象。“真上溢”是一种出错状态,应设法避免。
(3)"假上溢"现象:由于入队和出队操作中,头尾指针只增加不减小,致使被删元素的空间永远无法重新利用。当队列中实际的元素个数远远小于向量空间的规模时,也可能由于尾指针已超越向量空间的上界而不能做入队操作。该现象称为"假上溢"现象。
循环队列
在实际使用队列时,为了使队列空间能重复使用,往往对队列的使用方法稍加改进:无论插入或删除,一旦rear指针增1或front指针增1 时超出了所分配的队列空间,就让它指向这片连续空间的起始位置。自己真从MaxSize-1增1变到0,可用取余运算rear%MaxSize和front%MaxSize来实现。这实际上是把队列空间想象成一个环形空间,环形空间中的存储单元循环使用,用这种方法管理的队列也就称为循环队列。除了一些简单应用之外,真正实用的队列是循环队列。 [2]
在循环队列中,当队列为空时,有front=rear,而当所有队列空间全占满时,也有front=rear。为了区别这两种情况,规定循环队列最多只能有MaxSize-1个队列元素,当循环队列中只剩下一个空存储单元时,队列就已经满了。因此,队列判空的条件时front=rear,而队列判满的条件时front=(rear+1)%MaxSize。队空和队满的情况如图:

代码实现

from multiprocessing import Queue# 创建一个队列
A = Queue(10)  # 括号内传数字 生成的队列最大可以同时存放的数据量# 往队列中存数据
A.put('放进去一个资本家A')
A.put('放进去一个资本家B')
A.put('放进去一个资本家C')print(A.full())  #当前队列是否满
print(A.empty())  #当前队列是否空A.put('放进去一个资本家D')
A.put('放进去一个资本家E')
print(A.full())#A.put('资本家F也要被放进去')  # 当队列数据放满的时候 还有数据要放的话 程序会阻塞 直到有位置让出来 不会报错# 去队列中取数据
A1 = A.get()
A2 = A.get()
A3 = A.get()
A4 = A.get()
A5 = A.get()
print(A.empty())
#A6 = A.get_nowait()  # 没有数据直接报错queue.Empty
#A6 = A.get(timeout=3)  # 没有数据之后原地等待三秒之后再报错  queue.Empty
try:print(A5,"这个没有跑")#A6 = A.get(timeout=5)#print(A6)
except Exception as e:print('资本家全部跑了')#A6 = A.get()  # 队列中如果已经没有数据的话 get方法会原地阻塞
#print(A1, A2, A3, A4, A5)

效果

python学习笔记,python中的队列及代码实现相关推荐

  1. Python学习笔记--Python字符串连接方法总结

    声明: 这些总结的学习笔记,一部分是自己在工作学习中总结,一部分是收集网络中的知识点总结而成的,但不到原文链接.如果有侵权,请知会,多谢. python中有很多字符串连接方式,总结一下: 1)最原始的 ...

  2. (转载)[python学习笔记]Python语言程序设计(北理工 嵩天)

    作者:九命猫幺 博客出处:http://www.cnblogs.com/yongestcat/ 欢迎转载,转载请标明出处. 如果你觉得本文还不错,对你的学习带来了些许帮助,请帮忙点击右下角的推荐 阅读 ...

  3. Python学习笔记 - Python数据类型

    前言 在Python语言中,所有的数据类型都是类,每一个变量都是类的"实例".没有基本数据类型的概念,所以整数.浮点数和字符串也都是类. Python有6种标准数据类型:数字.字符 ...

  4. Python学习笔记——Python和基础知识

    Python优缺点 优点 简单----Python是一种代表简单主义思想的语言.阅读一个良好的Python程序就感觉像是在读英语一样,尽管这个英语的要求非常严格!Python的这种伪代码本质是它最大的 ...

  5. Python学习笔记 - Python语言概述和开发环境

    一.Python简介 1.1  Python语言简史 Python由荷兰人吉多·范罗苏姆(Guido van Rossum)于1989年圣诞节期间,在阿姆斯特丹,为了打发圣诞节的无聊时间,决心开发一门 ...

  6. Python学习笔记 Python概述 编码规范 输出与输入 变量 标识符

    Python学习第一天 Python的概述 1.Python的优缺点 1.1 优点: 1.2 缺点: 2.Python的编码规范 3.注释 3.Python的输出与输入 4.Python中的变量 5. ...

  7. 学python安装-Python学习笔记-Python安装

    Python安装 文章简介:本文介绍在不同操作系统中搭建Python编程环境. 一 搭建编程环境 在不同的操作系统中,Python存在细微的区别,下面介绍两个主要的Python版本. 1.1 Pyth ...

  8. Python学习笔记 - Python语法基础

    前言 本篇博文主要介绍Python中的一些最基础的语法,其中包括标识符.关键字.内置函数.变量.常量.表达式.语句.注释.模块和包等内容. 一.标识符.关键字和内置函数 任何一种语言都离不开标识符和关 ...

  9. [云炬python学习笔记]Numpy中内置函数min(),max(),sum()与Python中内置函数min(),max(),sum()性能对比分析

    众所周知,Python有许多内置函数(例如min(),max(),sum()),Numpy也有自己的内置函数(np.min(),np.max(),np.sum()).由于Numpy的函数是在编译码中执 ...

  10. Python学习笔记 列表中的冒号作用

    python中括号[ ]:用于定义列表或引用列表.数组.字符串及元组中元素位置 冒号: 用于定义分片.步长. a[ : n]表示从第0个元素到第n个元素(不包括n),a[1: ] 表示该列表中的第1个 ...

最新文章

  1. VSCode 安装 Go 插件、gopls 是个什么东东
  2. 范成法加工matlab_光学非球面技术原理与加工技术
  3. 用或非门构造D型触发器
  4. Jmeter基础(二)
  5. jpa 实体映射视图_JPA教程:映射实体–第1部分
  6. linux系统chmod缩写,文件属性控制命令chmod
  7. linux基础配置脚本,Linux中selinux基础配置教程详解
  8. js创建10万行表格 页面显示10万行数据
  9. linux symbol文件,[转] Linux文件系统之hard linksymbol link
  10. 史上最细的FIFO最小深度计算,(大多数笔试题中都会涉及)
  11. ppc+安装编译mysql_redhat7ppc安装
  12. H3C数通 H3CNE H3CSE 资料下载 肖哥视频下载
  13. (XWZ)的Python学习笔记Ⅷ--------numpy
  14. __kindof用法
  15. 用JavaScript实现元素自动旋转功能
  16. 找个问道自动架设工具
  17. 刷题笔记 | 朋友圈、岛屿的最大面积、岛屿数量
  18. matlab 正负数,matlab判断函数值正负程序
  19. 核磁谱图分析步骤_核磁一般氢谱和碳谱的解析步骤
  20. mp2551总线收发器芯片作用_高速CAN收发器MCP2551

热门文章

  1. Python:将输入的数字转换为列表
  2. HTML+CSS实战---------一个电商类的小型项目:品优购(三)
  3. 02-如何引入HandleBar.js
  4. 类加载过程以及类加载的机制(双亲委派模型)
  5. jQuery的ajaxSetup全局设置和单独设置覆盖情况
  6. 微信登录失败:redirect_uri域名与后台配置不一致,错误码10003
  7. vue项目中实现视频播放
  8. android 拍照插件,拍照录像,android原生插件
  9. 文本输入框小写转大写
  10. 整活--我是如何用OpenCV做了数字华容道游戏(附源码)