首页 > 其他分享 >队列的概念

队列的概念

时间:2024-11-03 21:52:04浏览次数:4  
标签:插入 队列 元素 概念 front 空间 rear

1. 什么是队列?

队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。队列中没有元素时,称为空队列。

队列的数据元素又称为队列元素。在队列中插入一个队列元素称为入队,从队列中删除一个队列元素称为出队。因为队列只允许在一端插入,在另一端删除,所以只有最早进入队列的元素才能最先从队列中删除,故队列又称为先进先出(FIFO—first in first out)线性表

2.顺序队列

建立顺序队列结构必须为其静态分配或动态申请一片连续的存储空间,并设置两个指针进行管理。一个是队头指针front,它指向队头元素;另一个是队尾指针rear,它指向下一个入队元素的存储位置,如图所示

每次在队尾插入一个元素时,rear增1; 每次在队头删除一个元素时,front增1。随着插入和删除操作的进行,队列元素的个数不断变化,队列所占的存储空间也在为队列结构所分配的连续空间中移动。当front=rear时,队列中没有任何元素,称为空队列。当rear增加到指向分配的连续空间之外时,队列无法再插入新元素,但这时往往还有大量可用空间未被占用,这些空间是已经出队的队列元素曾经占用过得存储单元。

顺序队列中的溢出现象:

(1) "下溢"现象:当队列为空时,做出队运算产生的溢出现象。“下溢”是正常现象,常用作程序控制转移的条件。

(2)"真上溢"现象:当队列满时,做进栈运算产生空间溢出的现象。“真上溢”是一种出错状态,应设法避免。

(3)"假上溢"现象:由于入队和出队操作中,头尾指针只增加不减小,致使被删元素的空间永远无法重新利用。当队列中实际的元素个数远远小于向量空间的规模时,也可能由于尾指针已超越向量空间的上界而不能做入队操作。该现象称为"假上溢"现象。

3. 循环队列

在实际使用队列时,为了使队列空间能重复使用,往往对队列的使用方法稍加改进:无论插入或删除,一旦rear指针增1或front指针增1 时超出了所分配的队列空间,就让它指向这片连续空间的起始位置。自己真从MaxSize-1增1变到0,可用取余运算rear%MaxSize和front%MaxSize来实现。这实际上是把队列空间想象成一个环形空间,环形空间中的存储单元循环使用,用这种方法管理的队列也就称为循环队列。除了一些简单应用之外,真正实用的队列是循环队列。

循环队列结构
在循环队列中,当队列为空时,有front=rear,而当所有队列空间全占满时,也有front=rear。为了区别这两种情况,规定循环队列最多只能有MaxSize-1个队列元素,当循环队列中只剩下一个空存储单元时,队列就已经满了。因此,队列判空的条件时front=rear,而队列判满的条件时front=(rear+1)%MaxSize。队空和队满的情况如图:

标签:插入,队列,元素,概念,front,空间,rear
From: https://blog.csdn.net/weixin_40847436/article/details/143471683

相关文章

  • 【Linux 25】网络套接字 socket 概念
    文章目录......
  • 华为OD机试-E卷,100分 - 最小的调整次数特异性双端队列Java & Python& JS & C++ & C
    最新华为OD机试题目描述有一个特异性的双端队列,该队列可以从头部或尾部添加数据,但是只能从头部移出数据。小A依次执行2n个指令往队列中添加数据和移出数据。其中n个指令是添加数据(可能从头部添加、也可能从尾部添加),依次添加1到n;n个指令是移出数据。现在要求移除数据的顺......
  • 【数论算法赌场】质数概念.判断和打表
    大家好我是#Y清墨,今天讲的是质数判断和打表。一.质数的相关概念质数的定义除了1和自身,找不到其它因数的数。例如7和13都是质数。最小的质数是2。合数除了1和自身,能找到其它因数的数。例如10,16均是合数。最小和合数是4。特殊情况数字1既不是质数,也不......
  • 【Orange Pi 5 Linux 5.x 内核编程】-等待队列(WaitQueue)
    等待队列(WaitQueue)文章目录等待队列(WaitQueue)1、等待队列介绍2、等待队列初始化2.1静态初始化2.2动态初始化3、队列任务排队3.1wait_event3.2wait_event_timeout3.3wait_event_cmd3.4wait_event_interruptible3.5wait_event_interruptible_ti......
  • Docker和k8s核心概念(理解友好版)
    背景这是在HWL负责网校云业务线测试时,给同事分享的基础概念文档。目录:一.Docker核心概念二.Kubernetes是什么及架构三.Kubernetes核心概念四.Deployment部署Pod操作一、Docker核心概念 1、为什么是Docker虚拟机:基础设施(Infrastructure)。服务器,或者是云主机。主......
  • 代码随想录算法训练营第十天|leetcode232.用栈实现队列、leetcode225. 用队列实现栈、
    1leetcode232.用栈实现队列题目链接:232.用栈实现队列-力扣(LeetCode)文章链接:代码随想录视频链接:栈的基本操作!|LeetCode:232.用栈实现队列哔哩哔哩bilibili自己的思路:真的第一次接触这个概念,完全没有任何思路,甚至不知道从何下手1.1基本概念栈就是相当于砌墙的砖头,先......
  • 【C++】布隆过滤器的概念与特点解析
    目录00.引入01.布隆过滤器的概念特点1:极低的内存消耗特点2:快速查询特点3:假阳性误判(禁止删除)02.布隆过滤器的底层实现00.引入上一篇博客介绍了位图这一数据结构,它可以在大量整数中快速查找某一数据是否存在,并且内存占用率很低(例如,查找40亿个整数只需0.5G空间)。博客链......
  • 栈与队列--栈
    一、基本介绍    回顾栈的知识二、代码实现#include<stdio.h>#include<stdlib.h>#defineSTACK_INIT_SIZE100//首次申请连续存储空间的大小#defineSTACKINCREMENT10//第二次申请#defineOVERFLOW-2#defineOK1#defineERROR0#defineTRUE1#......
  • 特朗普概念股分析:DJT和Phunware股价大涨:买还是卖?
    猛兽财经核心观点:(1)特朗普媒体科技集团的股价已经从9月份的低点上涨了280%。(2)随着特朗普赢得大选的概率上升,Phunware的股价也在大幅上涨(3)这些股票在大选后逆转的可能性越来越大。过去几周,特朗普媒体科技集团(DJT)和Phunware(PHUN)的股价表现非常好,一度成为了美股市场上表......