鱼C论坛

 找回密码
 立即注册
查看: 2559|回复: 5

数据结构队列的顺序存储结构

[复制链接]
发表于 2018-10-2 19:53:17 | 显示全部楼层 |阅读模式

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

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

x
最近在看小甲鱼的数据结构,有一些东西我看不明白,但是我觉得我没有错,例如小甲鱼说循环队列入队列时的代码这样写
InsertQueue(cycleQueue *q,Elemtype e)
{
   if((q->rear+1)%MAXSIZE==q->front)
                  return;//队列已满
    q->base[q->rear]=e;
    q->rear=(q->rear+1)%MAXSIZE
}


我认为应该把if((q->rear+1)%MAXSIZE==q->front)改为if((q->rear==q->front))才能判断队列是否已经满了
哪位大神帮帮我啊,好凌乱啊,谢谢啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-10-4 17:34:03 | 显示全部楼层
确实,但是你要怎样判断队列为空?你的方法就是在空的时候也是满,不是吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-10-5 20:13:08 | 显示全部楼层
claws0n 发表于 2018-10-4 17:34
确实,但是你要怎样判断队列为空?你的方法就是在空的时候也是满,不是吗?

但是小甲鱼的那种方法也不能判断队列是否为满啊,如果用小甲鱼的if判断,明明q->real里还可以存放一个数据怎么能反回呢,大神能不能给我一下正确的答案啊,emmmm,拜托了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-10-5 20:17:18 | 显示全部楼层
claws0n 发表于 2018-10-4 17:34
确实,但是你要怎样判断队列为空?你的方法就是在空的时候也是满,不是吗?

大神我还想问一下为什么小甲鱼给的代码里好多函数都没有数据类型啊#include <stdio.h>
#include <stdlib.h>

typedef char ElemType;

typedef struct BiTNode
{
        char data;
        struct BiTNode *lchild, *rchild;
} BiTNode, *BiTree;

// 鍒涘缓涓
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-10-5 20:43:30 | 显示全部楼层
小仙儿 发表于 2018-10-5 20:13
但是小甲鱼的那种方法也不能判断队列是否为满啊,如果用小甲鱼的if判断,明明q->real里还可以存放一个数 ...

那一集的?没印象,让我想一想
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-10-5 21:07:19 | 显示全部楼层
唔,楼主,可否把你 cycleQueue 的结构发上来?或者有更完整的代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-6-25 14:10

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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