鱼C论坛

 找回密码
 立即注册
查看: 3569|回复: 7

【数据结构】循环队列的插入问题

[复制链接]
发表于 2013-6-21 23:27:59 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 小水 于 2013-6-21 23:51 编辑

今天看了循环队列的插入删除 对插入有个地方不懂 就是判断队列满  即 if((Q->rear+1)%MANQSIZE==Q->front)return ERROR;

比如像视频里面讲的  队列的大小是5,开始时Q->rear=Q->front=0
那么我一直插入 当插到第五个元素 即q->rear指向数组地址是a【4】 那么(q->rear+1)%模不就是0 不就等于q->front
那么不就返回错误了 即队列满了 但是队列没有满啊
谁能跟我具体分析下 第五个元素即队列满之前那个元素的插入过程


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2013-6-22 06:45:28 | 显示全部楼层
队列大小只有5,你插入了五个元素本来就满了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2013-6-22 18:31:13 | 显示全部楼层

但是当我插入最后一个的时候不就返回错误 自动结束了吗  那我不是第五个就插不进去了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-6-22 23:28:37 | 显示全部楼层
一般就是这样的,循环队列一般会牺牲一个空间。这样就解决了都知道0 的问题。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-6-22 23:29:39 | 显示全部楼层
就是长度为5的,只能放4个数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-6-23 00:25:00 | 显示全部楼层
小水 发表于 2013-6-22 18:31
但是当我插入最后一个的时候不就返回错误 自动结束了吗  那我不是第五个就插不进去了

你把判断的放后面不就好了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2013-6-28 18:45:08 | 显示全部楼层
可里@天意社区 发表于 2013-6-22 23:28
一般就是这样的,循环队列一般会牺牲一个空间。这样就解决了都知道0 的问题。

懂了  谢谢哈
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-8-26 15:50:01 | 显示全部楼层
不是他们说的那样,空间为5自然能放5个数没有说要牺牲哪一个空间的,假设q->front=1,q->rear=1
MAXSIZE=5
//插入操作··········
if((q->rear+1)%MAXSIZE==q->front)
{
      retrun 0;
}
当q->rear=5时在判断
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-20 07:36

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表