数据结构队列.ppt
《数据结构队列.ppt》由会员分享,可在线阅读,更多相关《数据结构队列.ppt(40页珍藏版)》请在第壹文秘上搜索。
1、3.2 3.2 队列队列 3.2.1 3.2.1 队列的定义队列的定义 返回返回 3.2.2 3.2.2 队列的顺序存储结构及队列的顺序存储结构及其基本运算的实现其基本运算的实现 3.2.3 3.2.3 队列的链式存储结构及队列的链式存储结构及其基本运算的实现其基本运算的实现3.2.4 3.2.4 队列的应用例子队列的应用例子 队列简称队队列简称队,它也是一种运算受限的线性表它也是一种运算受限的线性表,其限其限制仅允许在表的一端进行插入制仅允许在表的一端进行插入,而在表的另一端进行而在表的另一端进行删除。删除。 我们把进行插入的一端称做我们把进行插入的一端称做队尾队尾(rear),进行删除进行
2、删除的一端称做的一端称做队首队首(front)。 向队列中插入新元素称为向队列中插入新元素称为进队进队或或入队入队,新元素进队新元素进队后就成为新的队尾元素;从队列中删除元素称为后就成为新的队尾元素;从队列中删除元素称为出队出队或或离队离队,元素出队后元素出队后,其后继元素就成为队首元素。其后继元素就成为队首元素。 3.2.1 3.2.1 队列的定义队列的定义 队列的入队和出队操作示意图队列的入队和出队操作示意图 3.2.2 3.2.2 队列的顺序存储结构及其基本运算的实现队列的顺序存储结构及其基本运算的实现 假设队列的元素个数最大不超过整数假设队列的元素个数最大不超过整数MaxSize,所有
3、的元素都具有同一数据类型所有的元素都具有同一数据类型ElemType,则顺序则顺序队列类型队列类型SqQueue定义如下定义如下: typedef struct ElemType dataMaxSize; int front,rear;/*队首和队尾指针队首和队尾指针*/ SqQueue 从 前 图 中 看 到从 前 图 中 看 到 , 图图 ( a ) 为 队 列 的 初 始 状 态为 队 列 的 初 始 状 态 , 有有front=rear成立成立,该条件可以作为队列空的条件。该条件可以作为队列空的条件。 那么能不能用那么能不能用rear=MaxSize-1作为队满的条件呢?作为队满的条件
4、呢?显然不能显然不能,在图在图(d)中中,队列为空队列为空,但仍满足该条件。这时但仍满足该条件。这时入队时出现入队时出现“上溢出上溢出”,这种溢出并不是真正的溢出这种溢出并不是真正的溢出,在在elem数组中存在可以存放元素的空位置数组中存在可以存放元素的空位置,所以这是一种所以这是一种假溢出。假溢出。 为了能够充分地使用数组中的存储空间为了能够充分地使用数组中的存储空间,把数组的把数组的前端和后端连接起来前端和后端连接起来,形成一个环形的顺序表形成一个环形的顺序表,即把存储即把存储队列元素的表从逻辑上看成一个环队列元素的表从逻辑上看成一个环,称为循环队列。称为循环队列。 循环队列首尾相连循环队
5、列首尾相连,当队首当队首front指针满足指针满足 front=MaxSize-1后后,再前进一个位置就自动到再前进一个位置就自动到0,这可这可以利用除法取余的运算以利用除法取余的运算()来实现来实现: 队首指针进队首指针进1:front=(front+1)MaxSize 队尾指针进队尾指针进1:rear=(rear+1)MaxSize 循环队列的除头指针和队尾指针初始化时都置循环队列的除头指针和队尾指针初始化时都置0:front=rear=0。在入队元素和出队元素时。在入队元素和出队元素时,指针都按指针都按逆时针方向进逆时针方向进1。 怎样区分这两者之间的差别呢怎样区分这两者之间的差别呢?在
6、入队时少用一个在入队时少用一个数据元素空间数据元素空间,以队尾指针加以队尾指针加1等于队首指针判断队满等于队首指针判断队满,即队满条件为即队满条件为: (q-rear+1) % MaxSize=q-front队空条件仍为队空条件仍为: q-rear=q-front rear rear 0 1 2 3 4 front (a)空队空队 (b)a,b,c 入队入队 rear 0 1 2 3 4 front a b c 0 1 2 3 4 a b c d front (c)d 入队入队,队满队满 rear 0 1 2 3 4 c d front (d)出队出队 2 次次 rear 0 1 2 3 4
7、front (e)出队出队 2 次次,队空队空 循环队的入队和出队操作示意图循环队的入队和出队操作示意图 在循环队列中在循环队列中,实现队列的基本运算算法如下实现队列的基本运算算法如下: (1) 初始化队列初始化队列InitQueue(&q) 构造一个空队列构造一个空队列q。将。将front和和rear指针均设置成初指针均设置成初始状态即始状态即0值。对应算法如下值。对应算法如下: void InitQueue(SqQueue *&q) q=(SqQueue *)malloc (sizeof(SqQueue);q-front=q-rear=0; (2) 销毁队列销毁队列ClearQueue(&
8、q) 释放队列释放队列q占用的存储空间。对应算法如下占用的存储空间。对应算法如下: void ClearQueue(SqQueue *&q) free(q); (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,然后将元素添
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 队列
