首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

队列的基本操作(顺序队列、循环队列、链式队列

队列的基本操作包括: 初始化队列:InitQueue(Q) 操作前提:Q为未初始化的队列操作结果:将Q初始化为一个空队列。...判断队列是否为空:IsEmpty(Q) 操作前提:队列Q已经存在。 操作结果:若队列为空则返回1,否则返回0。...判断队列是否已满:IsFull(Q) 操作前提:队列Q已经存在。 操作结果:若队列为满则返回1,否则返回0。...入队操作:EnterQueue(Q,data) 操作前提:队列Q已经存在。 操作结果:在队列Q的队尾插入data。...出队操作:DeleteQueue(Q,&data) 操作前提:队列Q已经存在且非空。 操作结果:将队列Q的队头元素出队,并使用data带回出队元素的值。

2.9K50

队列的基本操作

这一章我们来看队列 队列的概念: 队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。...进行插入操作的端称为队尾,进行删除操作的端称为队头。 其实我们来对比栈,栈的特点是只能在一端进行操作的,而队列是一端插入一端删除。...用一句很有歧义却很形象的话来讲两者的区别就是:栈就是插进去抽出来,而队列是插进去吐出来。 我们还是上图来更加直观的看队列 队列分为两种,一种是顺序队列,一种是循环队列。...其实从存储结构上讲,队列也分为两种,一种是顺序队列,一种是链队列。 如果从存储上加以区分的话,在实际的物理空间中,数据集中存储的队列是顺序队列,分散存储的队列是链队列。...我们来看顺序表实现队列操作 上代码: 我们这样实现就很简单,避免了使用结构体 #include int PushQueue(int *a,int rear,int data){

36730

队列的基础操作

队列是一种特殊的线性表,只允许在表的前端进行删除操作,而在表的后端进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。...struct queue { int inner; }Queue; Queue a[SIZE]; Queue *head = NULL; Queue *tail = NULL; /*(1)初始化队列...操作结果:构造了一个空队; (2)入队操作: In_Queue(Queue *q, int x),初始条件: 队q 存在。...操作结果: 对已存在的队列q,插入一个元素x 到队尾,队发生变化; (3)出队操作: Out_Queue(Queue *q),初始条件: 队q 存在且非空,操作结果: 删除队首元素,并返回其值,队发生变化...存在,操作结果: 若q 为空队则返回为1,否则返回为0。

28010

python队列Queue

Queue #1 环境 Python3.7.3 #2 开始 from queue import Queue,LifoQueue,PriorityQueue #2.1 队列种类 FIFO(先进先出) q...一旦达到上限,插入会导致阻塞,直到队列中的数据被消费掉。如果maxsize小于或者等于0,队列大小没有限制。...---- #2.2 操作 入队 put(item, block=True, timeout=None) # item: 入队的数据(任何数据类型都可以) # block: bool型,默认True #...timeout: 超时时间,默认None # 1.当block为默认值时,如果队列已经处于"满队"状态,还要继续往队列插入数据,这时timeout的值就是程序抛异常的时间(timeout=None时,...获取队列大小 q.qsize() 获取队列是否为空 # 如果队列为空,返回True,反之False q.empty() 判断队列是否"满队" # 如果队列满了,返回True,反之False q.full

58230

python算法队列

一、队列的特征性: 先进先出 二、类定义队列 1、实例属性 a.first节点 b.last节点 每一个新元素进来时,都是从最后面插入进来;每一个元素要出去,都是从开头向外出。...2、实例方法 a.进队列 enqueue 核心算法: 判断队列是否为空,如果是空则first,last都指向新加入的结点node; 如果不为空,这first指向队列第一个元素位置,在队尾插入元素完成后...,last指向向后加1 b.出队列 dequeue 核心算法: 参数:None 返回值:节点的值 队列为空时,return None;队列不为空,记录首节点first, 然后将下一个节点的值赋给first...3、练习:用上述的代码,完成67,45,34节点顺序放入队列,之后从队列的头部开始访问队列里的每一个元素。

48430

Python| 队列 Queue

一 前言 本文算是一次队列的学习笔记,Queue 模块实现了三种类型的队列,它们的区别仅仅是队列中元素被取回的顺序。在 FIFO 队列中,先添加的任务先取回。...在 LIFO 队列中,最近被添加的元素先取回(操作类似一个堆栈)。优先级队列中,元素将保持排序( 使用 heapq 模块 ) 并且最小值的条目第一个返回。...值得注意的是 Python 2.X 版本中调用队列需要引用 importQueue 而在Python 3.X版本中则需要 importqueue 二 队列特性 2.1 Queue的常用函数 Queue常用的方法...说明 这里生产者生产馒头并将馒头通过 put()放到全局的队列中,消费者从使用 get()队列中获取馒头然后调用 task_done() 通知队列中的馒头已经被消费者获取。...推荐阅读 https://docs.python.org/zh-cn/3/library/queue.html https://python-parallel-programmning-cookbook.readthedocs.io

1K31

python实现队列

队列是一种先进先出的数据类型,它的跟踪原理类似于在超市收银处排队,队列里的的第一个人首先接受服务,新的元素通过入队的方式添加到队列的末尾,而出队就是将队列的头元素删除。...我们可以设置一个类,用列表来存放栈中元素的信息,利用列表的append()和pop()方法可以实现队列的入队enqueue和出队dequeue的操作,上面栈一个元素每次出去是列表的最后一个,直接用list.pop...()出栈,而出队列每次是第一个,所以要用list.pop(0)出队列 代码如下: class Queue(): def __init__(self,size): self.size...self.front=-1; self.rear=-1; self.queue=[]; def enqueue(self,ele): #入队操作...self.queue.append(ele) self.rear=self.rear+1 def dequeue(self): #出队操作

1.2K50

Python实现队列

关于队列的介绍,请参考:栈和队列简介 队列的数据存储结构可以是顺序表,也可以是链表,本篇使用 Python 来分别实现顺序队列和链队列。 ?...一、实现顺序队列 顺序队列是使用顺序表存储数据的队列Python 中的列表元组都属于顺序表,下面使用列表来存储数据,实现顺序队列。...Python 中的列表有很多自带的方法,所以将存储数据的列表设置成私有属性,避免用户在类外面链式调用列表的其他方法。如果用户直接在类外面操作列表,则队列“先进先出”的规则可能会被破坏。...length(): 返回顺序队列的长度。顺序队列的长度就是存储数据的列表长度。 check(index): 返回顺序队列中指定位置的数据。...|Z|Y|X|V|U U |Z|Y|X|V link queue length: 4 index member is: X 以上就是用 Python 实现的顺序队列及链队列

51330

C语言队列的基本操作

本篇介绍一下编程中比较重要的一个数据结构队列队列有个很显著的标志,对其中的数据是先进先出,如果是顺序存储结构可以说就是一个受限的数组,对链式存储结构就只能说是符合先进先出的规则了,这种数据结构在我们真正的编程中还是相当常用的...实际中根据需要去定制自己的队列。...开始 顺序队列操作 首先我们来介绍一下顺序存储结构下的队列的定义和基本操作 添加适当的头文件,定义一个顺序存储数据结构, 这里需要添加头文件和定义一个队列的顺序数据结构 #include <stdio.h...,在顺序队列中,可以从数组的方式去理解,这样将会让你理解起来更简单 链式队列操作 首先我们来介绍一下顺序存储结构下的队列的定义和基本操作 添加适当的头文件,定义一个队列链式存储数据结构, 这里需要添加头文件和定义一个队列的链式存储数据结构...,只要理解了先进先出的逻辑,和了解一下指针操作就可以很容易的写出队列的节本操作

75131

37.python 线程队列PriorityQueue(优先队列

在 线程队列Queue / 线程队列LifoQueue 文章中分别介绍了先进先出队列Queue和先进后出队列LifoQueue,而今天给大家介绍的是最后一种:优先队列PriorityQueue,对队列中的数据按照优先级排序...usr/bin/env python # -*- coding:utf-8 _*- """ @Author:何以解忧 @Blog(个人博客地址): https://www.codersrc.com/  ...@File:python_priorityqueue.py @Time:2019/11/29 1queue5:25   @Motto:不积跬步无以至千里,不积小流无以成江海,程序人生的精彩需要坚持不懈地积累...猜你喜欢: 1.python线程队列Queue-FIFO 2.python线程队列LifoQueue 3.python线程互斥锁Lock 4.python线程时间Event 转载请注明:猿说Python...» python线程队列PriorityQueue(优先队列

2.7K20
领券