C++中的队列插入,这部分是什么意思啊?
voidenqueue(linkqueue&hq,elemtypeitem){lnode*newptr=newlnode;newptr->data=item;newptr...
void enqueue(linkqueue &hq,elemtype item)
{
lnode *newptr=new lnode;
newptr->data=item;
newptr->next=NULL;
if(hq.rear=NULL)
{
hq.front=hq.rear=NULL;
}
else
hq.rear=hq.real->next=newptr;
}
上面这几行各是什么意思啊?请给注释!!!
已经给结构体结为类型为
struct lnode
{
elemtype data;
lnode *next;
};
struct linkqueue
{
lnode *front;
lnode *rear;
}; 展开
{
lnode *newptr=new lnode;
newptr->data=item;
newptr->next=NULL;
if(hq.rear=NULL)
{
hq.front=hq.rear=NULL;
}
else
hq.rear=hq.real->next=newptr;
}
上面这几行各是什么意思啊?请给注释!!!
已经给结构体结为类型为
struct lnode
{
elemtype data;
lnode *next;
};
struct linkqueue
{
lnode *front;
lnode *rear;
}; 展开
展开全部
lnode *newptr=new lnode; ///创建一个结构体指针
newptr->data=item; ///结构体成员赋值
newptr->next=NULL; ///结构体成员指向空
if(hq.rear=NULL) ///队列尾是否为空, 这个判断是错误的啊
{
hq.front=hq.rear=NULL; ///空队列为对头指向队尾
}
else
hq.rear=hq.real->next=newptr; hq.real->next=队尾的下一个接点为newptr,并作为hq.rear
newptr->data=item; ///结构体成员赋值
newptr->next=NULL; ///结构体成员指向空
if(hq.rear=NULL) ///队列尾是否为空, 这个判断是错误的啊
{
hq.front=hq.rear=NULL; ///空队列为对头指向队尾
}
else
hq.rear=hq.real->next=newptr; hq.real->next=队尾的下一个接点为newptr,并作为hq.rear
展开全部
这个入队操作,先是生成一个新结点并赋值,然后再看队列是否为空.hq.rear==NULL表示空,这时候,newptr将成为队列中唯一一个元素,所以直接让头结点的首,尾指针都指向newptr即可(我估计这里代码有误,不应该是NULL,应该是newptr).如果队列不为空,那么新结点要放在队尾,所以要hq.rear->next=newptr,然后新的尾结点指针要指向新结点,所以hq.rear=hq.rear->next
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询