鱼C论坛

 找回密码
 立即注册
查看: 2127|回复: 2

[已解决]礼貌求助,入队列操作

[复制链接]
发表于 2020-3-16 14:29:05 | 显示全部楼层 |阅读模式

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

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

x
InsertQueue(LinkQueue *q, ElemType e)
{
QueuePtr p;
p = (QueuePtr )malloc(sizeof(QNode));
if(p==NULL)
exit(0);
p->data = e;
p->next = NULL;
q->rear->next = p;
q->rear = p;
}

这串代码是入队列操作,但是这里最后两行代码有点疑问呀?把p结点赋给q->rear->next 和q->rear,那q->rear->next 和q->rear不是一样了吗?
这里有没有多此一举?q->rear->next和q->rear有什么区别呀?
不懂就问,冒昧打扰大家!礼貌求回帖

最佳答案
2020-3-16 14:33:25
q->rear是链队的尾指针,指向链队的最后一个元素。q->rear->next指的是链队最后一个元素的指针域。p是要入队的新结点。
q->rear->next=p是新结点入队的操作,即原来的最后一个结点的指针域里的指针指向了p,所以p就入队了,成为链队的最后一个结点。
q->rear=p,就是链队的尾指针指向刚刚入队的尾结点p,为了再将新的结点入队。
这样,若再将新的结点入队再重复这两句代码即可。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-3-16 14:33:25 | 显示全部楼层    本楼为最佳答案   
q->rear是链队的尾指针,指向链队的最后一个元素。q->rear->next指的是链队最后一个元素的指针域。p是要入队的新结点。
q->rear->next=p是新结点入队的操作,即原来的最后一个结点的指针域里的指针指向了p,所以p就入队了,成为链队的最后一个结点。
q->rear=p,就是链队的尾指针指向刚刚入队的尾结点p,为了再将新的结点入队。
这样,若再将新的结点入队再重复这两句代码即可。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-3-16 14:38:17 | 显示全部楼层
sunrise085 发表于 2020-3-16 14:33
q->rear是链队的尾指针,指向链队的最后一个元素。q->rear->next指的是链队最后一个元素的指针域。p是要入 ...

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-23 01:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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