队列是什么意思

2021-03-06 22:33:49 字数 4964 阅读 8512

1楼:匿名用户

队列是常用数据结构之一。队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。

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

2楼:學雅思

队列是一种线性表,只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。

队列的数据元素又称为队列元素。在队列中插入一个队列元素称为入队,从队列中删除一个队列元素称为出队。因为队列只允许在一端插入,在另一端删除,所以只有最早进入队列的元素才能最先从队列中删除,故队列又称为先进先出。

扩展资料

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

在实际使用队列时,为了使队列空间能重复使用,往往对队列的使用方法稍加改进:无论插入或删除,一旦rear指针增1或front指针增1 时超出了所分配的队列空间,就让它指向这片连续空间的起始位置。

3楼:听不清啊

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

队列中没有元素时,称为空队列。

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

顺序队列

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

每次在队尾插入一个元素是,rear增1;每次哎队头删除一个元素时,front增1。随着插入和删除操作的进行,队列元素的个数不断变化,队列所占的存储空间也在为队列结构所分配的连续空间中移动。当front=rear时,队列中没有任何元素,称为空队列。

当rear增加到指向分配的连续空间之外时,队列无法再插入新元素,但这时往往还有大量可用空间未被占用,这些空间是已经出队的队列元素曾经占用过得存储单元。

顺序队列中的溢出现象:

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

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

(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。

队列的数组实现

队列可以用数组q[1…m]来存储,数组的上界m即是队列所容许的最大容量。在队列的运算中需设两个指针:head,队头指针,指向实际队头元素;tail,队尾指针,指向实际队尾元素的下一个位置。

一般情况下,两个指针的初值设为0,这时队列为空,没有元素。数组定义q[1…10]。q(i) i=3,4,5,6,7,8。

头指针head=2,尾指针tail=8。队列中拥有的元素个数为:l=tail-head。

现要让排头的元素出队,则需将头指针加1。即head=head+1这时头指针向上移动一个位置,指向q(3),表示q(3)已出队。如果想让一个新元素入队,则需尾指针向上移动一个位置。

即tail=tail+1这时q(9)入队。当队尾已经处理在最上面时,即tail=10,如果还要执行入队操作,则要发生"上溢",但实际上队列中还有三个空位置,所以这种溢出称为"假溢出"。

克服假溢出的方法有两种。一种是将队列中的所有元素均向低地址区移动,显然这种方法是很浪费时间的;另一种方法是将数组存储区看成是一个首尾相接的环形区域。当存放到n地址后,下一个地址就"翻转"为1。

在结构上采用这种技巧来存储的队列称为循环队列。

队列和栈一样只允许在断点处插入和删除元素。

循环队的入队算法如下:

1、tail=tail+1;

2、若tail=n+1,则tail=1;

3、若head=tail,即尾指针与头指针重合了,表示元素已装满队列,则作上溢出错处理;

4、否则,q(tail)=x,结束(x为新入出元素)。

队列和栈一样,有着非常广泛的应用。

注意:(1)有时候队列中还会设置表头结点,就是在队头的前面还有一个结点,这个结点的数据域为空,但是指针域指向队头元素。

(2)另外,上面的计算还可以利用下面给出的公式cq.rear=(cq.front+1)/max;

当有表头结点时,公式变为cq.rear=(cq.front+1)/(max+1)。

队列的链表实现

在队列的形成过程中,可以利用线性链表的原理,来生成一个队列。

基于链表的队列,要动态创建和删除节点,效率较低,但是可以动态增长。

队列采用的fifo(first in first out),新元素(等待进入队列的元素)总是被插入到链表的尾部,而读取的时候总是从链表的头部开始读取。每次读取一个元素,释放一个元素。所谓的动态创建,动态释放。

因而也不存在溢出等问题。由于链表由结构体间接而成,遍历也方便。

队列的基本运算编辑

(1)初始化队列:init_queue(q) ,初始条件:队q 不存在。操作结果:构造了一个空队;

(2)入队操作: in_queue(q,x),初始条件: 队q 存在。操作结果: 对已存在的队列q,插入一个元素x 到队尾,队发生变化;

(3)出队操作: out_queue(q,x),初始条件: 队q 存在且非空,操作结果: 删除队首元素,并返回其值,队发生变化;

(4)读队头元素:front_queue(q,x),初始条件: 队q 存在且非空,操作结果: 读队头元素,并返回其值,队不变;

(5)判队空操作:empty_queue(q),初始条件: 队q 存在,操作结果: 若q 为空队则返回为1,否则返回为0。

在stl中,对队列的使用很是较完美

下面给出循环队列的运算算法:

(1)将循环队列置为空

//将队列初始化

sequeue::sequeue()

(2)判断循环队列是否为空

int sequeue::empty()

(3)在循环队列中插入新的元素x

void sequeue::addq(elemtype x)

}(4)删除队列中队首元素

elemtype sequeue::delq()

else

}(5)取队列中的队首元素

elemtype sequeue::front()

4楼:一骑当后

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

在队列这种数据结构中,最先插入在元素将是最先被删除;反之最后插入的元素将最后被删除,因此队列又称为“先进先出”(fifo—first in first out)的线性表。

队列空的条件:front=rear

队列满的条件: rear = maxsize

队列可以用数组q[1…m]来存储,数组的上界m即是队列所容许的最大容量。在队列的运算中需设两个指针:head,队头指针,指向实际队头元素的前一个位置;tail,队尾指针,指向实际队尾元素所在的位置。

一般情况下,两个指针的初值设为0,这时队列为空,没有元素。图1 ( a)画出了一个由6个元素构成的队列,数组定义q[1…10]。q(i) i=3,4,5,6,7,8头指针head=2,尾指针tail=8。

队列中拥有的元素个数为:l=tail-head现要让排头的元素出队,则需将头指针加1。即head=head+1这时头指针向上移动一个位置,指向q(3),表示q(3)已出队。

见图1 (b)。如果想让一个新元素入队,则需尾指针向上移动一个位置。即tail=tail+1这时q(9)入队,见图1 (c)。

当队尾已经处理在最上面时,即tail=10,如果还要执行入队操作,则要发生"上溢",但实际上队列中还有三个空位置,所以这种溢出称为"假溢出"。

克服假溢出的方法有两种。一种是将队列中的所有元素均向低地址区移动,显然这种方法是很浪费时间的;另一种方法是将数组存储区看成是一个首尾相接的环形区域。当存放到n地址后,下一个地址就"翻转"为1。

在结构上采用这种技巧来存储的队列称为循环队列。

队列和栈一样只允许在断点处插入和删除元素。

循环队的入队算法如下:

1、tail=tail+1;

2、若tail=n+1,则tail=1;

3、若head=tail尾指针与头指针重合了,表示元素已装满队列,则作上溢出错处理;

4、否则,q(tail)=x,结束(x为新入出元素)。

穿越火线“队伤”是什么意思,cf队伤44什么意思,,,,,,,,

1楼 队伤指的是 在爆破模式 开启的 队友伤害模式。比如你不小心误伤了队友,伤害很多次也就是合计起来。。 2楼 cf沙鹰修罗 是指队友伤害,就是自己队打自己队可以造成伤害,建议不要开队伤 cf队伤44什么意思,,,,,,,, 3楼 匿名用户 队伤 必须在潜伏打。4个打4个。输了退服 或者退网 上男下...

农村说的“大队”是什么意思,农村几大队是什么意思???比如1队 2队 什么的 然后在一个大队的

1楼 54程太太 大队指的是村庄。 定义 大队是中华人民共和国的一个比较常见的行政单位。一个大队由组成的若干成员组成。其成员是大队的每一人,他们也是组成大队的基本元素。 解释 1 大批军队。 唐司空图《华岳庙裴晋公题名》诗 岳前大队赴 淮西 ,从此中原息皷鼙。 2 泛指许多人的队伍。 3 古军队编制...

汽轮机解列是什么意思,发电机解列是什么意思

1楼 仙人球果乳 汽轮机不能说是解列,发电机可以说是解列,汽轮机是打闸停机, 发电机解列是什么意思 2楼 匿名用户 就是将发电机退出与电网的并网运行,电力运行人员愿意说将发电机解列 3楼 匿名用户 发电机并列是指把发电机与电网连接在一起,以便向电网送电。发电机解列就是把发电机与电网断开。需要先减有功...