不多解释,直接上代码,代码已经写了注释!
//队列链式结构的基本操作:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
typedef int QueueElememtType;
typedef struct QNode//链队的定义
{
QueueElememtType data;//数据成员,数据域
struct QNode* next;//指针域
}QNode, * QueuePtr;
typedef struct//队头队尾指针
{
QueuePtr front;//还可以写成QNode*front
QueuePtr rear;//还可以写成QNode*rear
}LinkQueue;
//链队的初始化
void InitQueue(LinkQueue*Q)//将Q初始化为一个空队列
{
Q->front = Q->rear = (QueuePtr)malloc(sizeof(QNode));//开辟空间
if (Q->front != NULL)//表示队Q不为空
{
Q->rear = Q->front;//将队列置空
Q->front->next = NULL;
}
}
//链队入队操作
int EnterQueue(LinkQueue*Q,QueueElememtType x)
{
QueuePtr p;
p = (QueuePtr)malloc(sizeof(QNode));//开辟空间
if (p != NULL)//说明申请成功
{
p->data = x;//将要入队的数据放入
p->next = NULL;
Q->rear->next = p;//把p插入队尾
Q->rear = p;//把p变为队尾
return 1;
}
else
return 0;
}
//链队的出队操作
int DeleteQueue(LinkQueue*Q,QueueElememtType*x)
{
QueuePtr p;
if (Q->front == Q->rear)//表示队列为空
{
printf("队列为空\n");
return 0;
}
p = Q->front->next;//头指针为空
*x= p->data;//将要出队的数据放入指针变量x中
Q->front->next = p->next;//指针后移
if (Q->rear == p)
{
Q->rear = Q->front;//如果p为队尾
}
free(p);//释放p
return 1;
}
//链队的遍历
int printQueue(LinkQueue* Q)
{
QueuePtr p;
printf("链队列中的元素");
if (Q->front->next != NULL)
{
p = Q->front->next;
do//循环打印队列里的元素
{
printf("%d", p->data);
p = p->next;
} while (p != NULL);
}
else
{
printf("队列为空\n");
printf("\n");
}
printf("\n");
return 0;
}
int main()
{
QueueElememtType x;
LinkQueue Q;
InitQueue(&Q);//初始化队列
for (int i=0; i < 5; i++)
{
int n;
scanf("%d", &n);
printf("元素%d 进队\n",n);
EnterQueue(&Q,n);
printQueue(&Q);
}
printf("进行出队操作!\n");
for (int i = 5; i>0; i--)
{
DeleteQueue(&Q, &x);
printQueue(&Q);
}
}
运行结果:
有不懂的欢迎随时提问!