|  | 
 
| 
#include <stdio.h>
x
马上注册,结交更多好友,享用更多功能^_^您需要 登录 才可以下载或查看,没有账号?立即注册  #include <stdlib.h>
 typedef struct QNode{
 int data;
 struct QNode * next;
 }QNode;
 QNode * initQueue(){
 QNode * queue=(QNode*)malloc(sizeof(QNode));
 queue->next=NULL;
 return queue;
 }
 QNode* enQueue(QNode * rear,int data){
 QNode * enElem=(QNode*)malloc(sizeof(QNode));
 enElem->data=data;
 enElem->next=NULL;
 //使用尾插法向链队列中添加数据元素
 rear->next=enElem;
 rear=enElem;
 return rear;
 }
 QNode* DeQueue(QNode * top,QNode * rear){
 QNode * p = NULL;
 if (top->next==NULL) {
 printf("\n队列为空");
 return rear;
 }
 p=top->next;
 printf("%d ",p->data);
 top->next=p->next;
 if (rear==p) {
 rear=top;
 }
 free(p);
 return rear;
 }
 int main() {
 QNode * queue,*top,*rear;
 queue=top=rear=initQueue();//创建头结点
 //向链队列中添加结点,使用尾插法添加的同时,队尾指针需要指向链表的最后一个元素
 rear=enQueue(rear, 1);
 rear=enQueue(rear, 2);
 rear=enQueue(rear, 3);
 rear=enQueue(rear, 4);
 //入队完成,所有数据元素开始出队列
 rear=DeQueue(top, rear);
 rear=DeQueue(top, rear);
 rear=DeQueue(top, rear);
 rear=DeQueue(top, rear);
 rear=DeQueue(top, rear);
 return 0;
 }
 
 
 
 
 //整个程序实现的是通过链表实现队列的先进先出。我理解的是,程序中top->next一直为NULL,因为这个程序一直在维护rear指针。
 | 
 |