数据结构:队列

一 队列的基本概念:

1.队列的定义:

队列(Queue)简称队,也是和栈一样是一种受限的线性表,只允许在表的一端进行插入,而在表的另一端进行删除。向队列中插入元素称为入队或进队;删除元素称为出队或离队。这和我们日常生活中的排队是一致的,最早排队的也是对早离队的,其操作的特性就是先进先出(First In First Out FIFO)。
队头 (Front) 允许删除的一端,又称队首。
队尾(Rear) 允许插入的一端。
空队列 不含元素的空链表。

二 队列的链式存储结构:

1.队列的存储结构:

复制代码
typedef int QDataType;
typedef struct QueueNode
{
	int val;
	struct QueueNode* next;
}QNode;

typedef struct Queue
{
	QNode* phead;
	QNode* ptail;
	int size;
}Queue;

2.队列的所有接口:

复制代码
//队列的初始化、销毁
void QueueInit(Queue* pq);
void QueueDestroy(Queue* pq);

// 入队列、 出队列
void QueuePush(Queue* pq, QDataType x);
void QueuePop(Queue* pq);

//获取队头、队尾元素
QDataType QueueFront(Queue* pq);
QDataType QueueBack(Queue* pq);

//判断队列是否为空
bool QueueEmpty(Queue* pq);

//获取队列元素个数
int QueueSize(Queue* pq);

3.队列的初始化:

复制代码
void QueueInit(Queue* pq)
{
	pq->phead = NULL;
	pq->ptail = NULL;
	pq->size = 0;
}

输出:

4.队列的销毁:

复制代码
void QueueDestroy(Queue* pq)
{
	assert(pq);
	QNode* cur = pq->phead;
	while (cur)
	{
		QNode* next = cur->next;
		free(cur);
		cur = next;
	}
	pq->phead = pq->ptail = NULL;
	pq->size = 0;
}

销毁:

5.入队列:

复制代码
void QueuePush(Queue* pq, QDataType x)
{
	assert(pq);
	QNode* Newnode = (QNode*)malloc(sizeof(QNode));
	if (Newnode == NULL)
	{
		perror("malloc error");
		exit(-1);
	}
	Newnode->next = NULL;
	Newnode->val = x;
	if (pq->ptail)
	{
		pq->ptail->next = Newnode;
		pq->ptail = Newnode;
	}
	else
	{
		pq->phead = pq->ptail = Newnode;//当最开始的时候我们让phead,ptail指针都指向Newnode
	}
	pq->size++;
}

输出:

6.出队列:

复制代码
void QueuePop(Queue* pq)
{
	assert(pq);
	assert(pq->phead != NULL);

	// 一个节点
	if (pq->phead->next == NULL)
	{
		free(pq->phead);
		pq->phead = pq->ptail = NULL;
	}
	// 多个节点
	else
	{
		QNode* next = pq->phead->next;
		free(pq->phead);
		pq->phead = next;
	}

	pq->size--;
}

输出:

7.获取队顶元素:

复制代码
QDataType QueueFront(Queue* pq)
{
	return pq->phead->val;
}

输出:

8.获取队尾数据:

复制代码
QDataType QueueBack(Queue* pq)
{
	return pq->ptail->val;
}

输出:

9.获取有效数据个数:

复制代码
int QueueSize(Queue* pq)
{
	return pq->size;
}

输出:

10.判断队列是否为空:

复制代码
bool QueueEmpty(Queue* pq)
{
	if (pq->ptail == NULL)
	{
		return false;
	}
	else
	{
		return true;
	}
}

输出:

11.打印队列:

队列与栈的总结:

队列 是一种遵循先进先出(FIFO)受限的线性数据结构。元素从队列的尾部添加,从队列的头部移除。队列通常用于模拟现实世界中按到达顺序处理项目的场景。

是一种遵循后进先出(LIFO)受限的线性数据结构。**元素从栈的顶部添加,从栈的顶部移除。**栈通常用于实现涉及回溯或解决递归问题的算法。

队列和栈是基础数据结构,具有不同的特性和应用。队列适用于按顺序管理项,而栈适用于实现涉及回溯或解决递归问题的算法。

相关推荐
灯厂码农2 小时前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法
wuyk5553 小时前
24. C 语言模块化:不是拆几个.c 文件那么简单
c语言·开发语言·stm32·单片机
qq_241585613 小时前
可用在中断中浮点数打印类似printf
c语言
C语言小火车5 小时前
C++ 快速排序(Quick Sort)深度精讲:分治思想、Lomuto 分区法及三数取中优化,面试手撕必会
c语言·开发语言·c++·面试·排序算法·快速排序
tachibana26 小时前
hot100 回文链表(234)
java·网络·数据结构·leetcode·链表
aaaameliaaa6 小时前
进制练习题【找出只出现一次的数字、交换两个变量(不创建临时变量)、统计二进制中1的个数、打印整数二进制的奇数位和偶数位、求两个数二进制中不同位的个数】
c语言·数据结构·笔记·算法
-dzk-6 小时前
【系统架构设计师】案例分析篇
开发语言·数据结构·python·算法·架构·系统架构·架构设计
灯厂码农6 小时前
C语言内存管理——内存对齐与共用体union
linux·服务器·c语言
伏 念9 小时前
AI Coding 零基础实战教程
c语言·进程·预处理
你家人养牛9 小时前
OOC Relation Plugin:C 语言面向对象 开发的高效辅助工具
c语言·vscode