用C语言实现链队列的基本操作

不多解释,直接上代码,代码已经写了注释!

//队列链式结构的基本操作:
#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);
	}
}

 运行结果:

有不懂的欢迎随时提问!

  • 19
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清潇沈默

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值