数据结构队列.ppt
《数据结构队列.ppt》由会员分享,可在线阅读,更多相关《数据结构队列.ppt(40页珍藏版)》请在课桌文档上搜索。
1、3.2 队列,3.2.1 队列的定义,返回,3.2.2 队列的顺序存储结构及其基本运算的实现,3.2.3 队列的链式存储结构及其基本运算的实现,3.2.4 队列的应用例子,队列简称队,它也是一种运算受限的线性表,其限制仅允许在表的一端进行插入,而在表的另一端进行删除。我们把进行插入的一端称做队尾(rear),进行删除的一端称做队首(front)。向队列中插入新元素称为进队或入队,新元素进队后就成为新的队尾元素;从队列中删除元素称为出队或离队,元素出队后,其后继元素就成为队首元素。,3.2.1 队列的定义,队列的入队和出队操作示意图,3.2.2 队列的顺序存储结构及其基本运算的实现,假设队列的元
2、素个数最大不超过整数MaxSize,所有的元素都具有同一数据类型ElemType,则顺序队列类型SqQueue定义如下:typedef struct ElemType dataMaxSize;int front,rear;/*队首和队尾指针*/SqQueue,从前图中看到,图(a)为队列的初始状态,有front=rear成立,该条件可以作为队列空的条件。那么能不能用rear=MaxSize-1作为队满的条件呢?显然不能,在图(d)中,队列为空,但仍满足该条件。这时入队时出现“上溢出”,这种溢出并不是真正的溢出,在elem数组中存在可以存放元素的空位置,所以这是一种假溢出。为了能够充分地使用数组
3、中的存储空间,把数组的前端和后端连接起来,形成一个环形的顺序表,即把存储队列元素的表从逻辑上看成一个环,称为循环队列。,循环队列首尾相连,当队首front指针满足 front=MaxSize-1后,再前进一个位置就自动到0,这可以利用除法取余的运算()来实现:队首指针进1:front=(front+1)MaxSize 队尾指针进1:rear=(rear+1)MaxSize 循环队列的除头指针和队尾指针初始化时都置0:front=rear=0。在入队元素和出队元素时,指针都按逆时针方向进1。,怎样区分这两者之间的差别呢?在入队时少用一个数据元素空间,以队尾指针加1等于队首指针判断队满,即队满条件
4、为:(q-rear+1)%MaxSize=q-front队空条件仍为:q-rear=q-front,循环队的入队和出队操作示意图,在循环队列中,实现队列的基本运算算法如下:(1)初始化队列InitQueue(,(2)销毁队列ClearQueue(,(3)判断队列是否为空QueueEmpty(q)若队列q满足q-front=q-rear条件,则返回1;否则返回0。对应算法如下:int QueueEmpty(SqQueue*q)return(q-front=q-rear);,(4)入队列enQueue(q,e)在队列不满的条件下,先将队尾指针rear循环增1,然后将元素添加到该位置。对应算法如下:
5、int enQueue(SqQueue*,(5)出队列deQueue(q,e)在队列q不为空的条件下,将队首指针front循环增1,并将该位置的元素值赋给e。对应算法如下:int deQueue(SqQueue*,例3.6 什么是队列的上溢现象和假溢出现象?解决它们有哪些方法?,答:在队列的顺序存储结构中,设头指针为front,队尾指针rear,队的容量(存储空间的大小)为MaxSize。当有元素加入到队列时,若 rear=MaxSize(初始时rear=0)则发生队列的上溢现象,该元素不能加入队列。特别要注意的是队列的假溢出现象:队列中还有剩余空间但元素却不能进入队列,造成这种现象的原因是由
6、于队列的操作方法所致。,解决队列上溢的方法有以下几种:(1)建立一个足够大的存储空间,但这样做会造成空间的使用效率降低。(2)当出现假溢出时可采用以下几种方法:采用平移元素的方法:每当队列中加入一个元素时,队列中已有的元素向队头移动一个位置(当然要有空闲的空间可供移动);,每当删除一个队头元素时,则依次移动队中的元素,始终使front指针指向队列中的第一个位置;采用循环队列方式:把队列看成一个首尾相接的循环队列,在循环队列上进行插入或删除运算时仍然遵循“先进先出”的原则。,例3.7 对于顺序队列来说,如果知道队首元素的位置和队列中元素个数,则队尾元素所在位置显然是可以计算的。也就是说,可以用队
7、列中元素个数代替队尾指针。编写出这种循环顺序队列的初始化、入队、出队和判空算法。,解:当已知队首元素的位置front和队列中元素个数count后:队空的条件为:count=0队满的条件为:count=MaxSize计算队尾位置rear:rear=(front+count)%MaxSize 对应的算法如下:typedef struct ElemType dataMaxSize;int front;/*队首指针*/int count;/*队列中元素个数*/QuType;/*队列类型*/,void InitQu(QuType*,int EnQu(QuType*,int DeQu(QuType*,in
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 队列
链接地址:https://www.desk33.com/p-229824.html