循环队列是通过指针来实现队列的头尾相接为什么是错的

 我来答
生活畅谈者
高能答主

2020-11-04 · 生活新鲜事,看我就知道
生活畅谈者
采纳数:418 获赞数:344733

向TA提问 私信TA
展开全部

循环队列中由于入队时尾指针向前追赶头指针,出队时头指针向前追赶尾指针,造成队空和队满时头尾指针均相等,因此无法通过条件front==rear来判别队列是空还是满。

另一种方式就是数据结构常用的:队满时(rear+1)%n==front,n为队列长度(所用数组大小),由于rear,front均为所用空间的指针,循环只是逻辑上的循环,所以需要求余运算。

扩展资料:

注意事项:

队空时,头尾指针应该相等。

队满时,头指针应该正好在尾指针后1位。

入队时,尾指针加1,出队时,头指针加1。

对Maxsize取模是因为是循环队列,并防止溢出。

参考资料来源:百度百科-循环队列

野人无事不言L
2016-01-13 · TA获得超过1413万个赞
知道顶级答主
回答量:2242万
采纳率:0%
帮助的人:141.3亿
展开全部
我记得循环队列其实就是个数组,是靠队头、队尾、下标来实现头尾相接 如队列A有5个位置,当到达A【4】时,判断到达队尾了,下标变道队头0,即可回到A【0】——队列头部。循环队列应该注意判断队列是否为空,是否满
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
后湘云4I
2020-12-24
知道答主
回答量:1
采纳率:0%
帮助的人:530
展开全部
其实就是个数组,靠队头队尾下标来实现的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式