在对链队列作出队操作时,会改变其头指针的值吗?为什么?
2个回答
展开全部
正确。
既然是队列,只能先进先出,所以只能删除front->next所指的节点,rear指针不动。但如果front->next == NULL,需要把头指针复制给尾指针。这时候队列就是空队列了。所以头尾指针可能都要修改。
假设head是指向队列的头结点指针,p为与duhead同类型的指针,那么head->next指向zhi的是队列的首结点,那dao么出队的操作为
p = head->next;//指向欲出队的结点
head->next = p->next;//这一步不能少
free(p);//销毁队首节点
扩展资料:
测试链接队列为空的条件是front为NULL。事实上,在链接队列中插人一个新的元素就是在链表的表尾链结点后添加一个新链结点;而删除一个元素的操作就是删除链表的第1个链结点。
链接队列的类型可以定义如下。
typedefstruct node{
OElemType data
struct node ,link;
} QNode,xQLink; /*定义一个链表队列类型*/
参考资料来源:百度百科-链接队列
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询