博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
循环队列
阅读量:6695 次
发布时间:2019-06-25

本文共 882 字,大约阅读时间需要 2 分钟。

循环队列是队列的一种顺序表示和实现的方法。

与顺序栈类似,在队列的顺序存储结构中,用一组地址连续的存储单元依次存放从队头到队尾的元素,如一维数组Queue[MAXSIZE]。

此外,由于队列中队头和队尾的位置都是动态变化的,因此需要附设俩个指针front和rear,分别指示队头元素和为元素在数组中的位置。

 

初始化时,令front=rear=0;

入队时,直接将新元素送入尾指针rear所指的单元,然后尾指针增1;

出队时,直接取出队头指针front所指的元素,然后头指针增1。

 

显然,在非空顺序队列中,rear==MAZSIZE时认为队满,但是可能由于之前的操作,有一部分数据进行了出队操作,

从而使front后移,将之前的存储空间空余出来。这种现象叫做假溢出。

 

为了解决这个问题,引入循环队列这个概念,即当rear==MAXSIZE之后,再入队时,就应该入的顺序存储空间位置0的位置,

这样就可达到队列空间的充分利用,此时判断队列是否已满的依据是 rear-front==MAXSIZE。

实现这种结构的方法是,通过模运算,

    队尾进队时,队尾指针变化:rear = (rear+1)%MAXSIZE,

    队头出队时,队头指针变化:front = (front+1)%MAXSIZE

 

此时,循序队列判空就不能再以简单的 rear==front 来判断了,循环队列的判空有俩种方法:

    第一种:损失一个存储单元,当队尾指针所指向的空单元的后继单元是队头元素所在的单元时,则停止入队。

        这样一来,队尾指针永远追不上队头指针,所以队满时 不会有 rear == front,

        此时的判满条件是 (rear+1)%MAXSIZE == front;

        判空条件仍为 rear == front。

    第二种:增设一个标志量tag,tag==0时表示队空,tag==1时表示队满,此方法不损失存储空间。

 

转载于:https://www.cnblogs.com/xxdfly/p/4384480.html

你可能感兴趣的文章
[leetcode] Jump Game II
查看>>
iOS开发技巧(系列十四:iOS7导航栏和iOS6的区别)
查看>>
Js针对window窗体大小设置
查看>>
MySQL 使用SELECT ... FOR UPDATE
查看>>
MYSQL级联查询,包括向上向下的级联
查看>>
Apache优化:修改最大并发连接数
查看>>
windows Socket 通信模型
查看>>
jquery validate案例1
查看>>
Redis应用场景
查看>>
不想工作的一天
查看>>
音效原理
查看>>
dom4j的生成xml并格式化输出
查看>>
Re-negotiation handshake failed: Not accepted b...
查看>>
价值百万的PPT是如何炼成的
查看>>
企业管理过程信息化自助开发平台架构研究与应用
查看>>
TDBadgedCell
查看>>
HMLabel
查看>>
为Redis配置自定义fastJson序列化工具类
查看>>
2015年用户界面工具干货资源精选
查看>>
开源 java CMS - FreeCMS2.3会员我的评论
查看>>