数据结构-------链式队列

#include <stdio.h>
#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)
{
    if(top->next==NULL)
    {
        printf("\n 队列为空");
        return rear;
    }
    QNode* 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;

}
root@book-virtual-machine:/mnt/hgfs/lua/C++# g++  -std=c++11 salman_0119.cpp -o salman_0119
root@book-virtual-machine:/mnt/hgfs/lua/C++# ./salman_0119
1 2 3 4
 队列为空root@book-virtual-machine:/mnt/hgfs/lua/C++#

猜你喜欢

转载自blog.csdn.net/aa804738534/article/details/113754871