【c++】模拟实现循环队列 三种方法(标识、浪费一个空间、计数器)

本文介绍了循环队列的概念,通过循环向量克服假溢出现象。详细阐述了三种模拟实现循环队列的方法:使用标识flag、浪费一个空间以及设置计数器Count。分别展示了每种方法的逻辑和代码实现,帮助理解如何判断队列的空和满状态。
摘要由CSDN通过智能技术生成

什么是循环队列?

为充分利用向量空间,克服”假溢出“现象的方法:将向量空间想象为一个首尾相接的圆环,并称这种向量为循环向量。存储在其中的队列称为循环队列(Circular Queue)。

假象成如图:


但实际上存储空间还是一段连续的空间。

空队列:


当有元素入队时:


元素出队:


元素继续入队时:


在这里吃瓜群众们可能有个疑问,队尾标记rear 是怎么就突然蹦到front的前面的?

观察我们可以发现当E入队时,rear = 5,

下一个将要入队的是F,那么按照假象的循环队列的话 rear应该变为0 ,也就是(rear+1)%容量,可以多计算几个值尝试,画图尝试一下,容易理解。

然后G入队时 rear+1 即可 。用一个对容量求余的方法,解决了 rear每次 向后推进的 改变。当然也可以判断入队时rear 是否等于容量 ,

当等于容量时࿰

  • 4
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值