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

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

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

 运行结果:用C语言实现链队列的基本操作_第1张图片

有不懂的欢迎随时提问!

你可能感兴趣的:(c语言,开发语言,数据结构)