qq_31750507 2015-12-05 22:31 采纳率: 52.6%
浏览 1500
已采纳

@数据结构大神:链队列的5种操作,42行判断队为空,为啥会错?求解释!`

 int Init_Queue(LinkQueue *Q)
{   
 Q=(LinkQueue*)malloc(sizeof(LinkQueue));
 if(Q==NULL) return 0;
 Q->front=(QueueNode*)malloc(sizeof(QueueNode));
 if(Q->front==NULL) return 0;
 Q->rear=(QueueNode*)malloc(sizeof(QueueNode));
 if(Q->rear==NULL) return 0;

 Q->front->next=head;//不仅需要头指针,还需要头节点 .定义头节点为空,怎么错了? 
 Q->rear->next=head;
 k=1;
 return 1;
}


int Empty_Queue(LinkQueue *Q)
{
 if((Q->front->next==NULL)&&(Q->rear->next==NULL)&&(k=1))
 return 1;//有头节点,但是为空 
 else return 0;
}


void EnQueue(LinkQueue *Q,int x)
{
 QueueNode *q;
 q=(QueueNode *)malloc(sizeof(QueueNode));
 if(q==NULL) exit(0);
 q->data=x;

 if(Empty_Queue(Q)==1)
 {
  head=q;head->next=Q->rear->next;
 }//q变成了头节点 .应该和后面建立联系 
 else
 {Q->rear->next=q;Q->rear=q;}//先给head数值 
}


int DeQueue(LinkQueue *Q)//把头节点删了,看和尾节点是否相同 
{
 if(Empty_Queue(Q)==1) exit(0);
 QueueNode *p;int x;
 p=Q->front->next;x=p->data;
 Q->front->next=p->next;

 if(Q->rear==p)//只有一个头节点,但不为空 
 {Q->front=Q->rear;}//没啥区别了 

 return x; 
}

int QueueFront(LinkQueue *Q) 
{
 int x;
 if(Empty_Queue(Q)==1) exit(0);
 x=Q->front->next->data;
 return x;
}

int main()
{   
    LinkQueue *Q;
 if(Init_Queue(Q)==1)
 {
  EnQueue(Q,1);
  EnQueue(Q,2);
  EnQueue(Q,3);DeQueue(Q);
  EnQueue(Q,4);DeQueue(Q);

  printf("QueueFront:%d\n",QueueFront(Q));
 }
 getch();
}

http://g.hiphotos.baidu.com/zhidao/wh%3D600%2C800/sign=6424807aef50352ab1342d0e6373d7ca/e824b899a9014c0830d1a7680c7b02087af4f411.jpg

  • 写回答

2条回答 默认 最新

  • ysuwood 2015-12-06 01:23
    关注

    代码不全,没有结构体LinkQueue

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器