数据结构之队列的实现

1.初始化

同之前文章,在这里不对前置操作进行说明,比如头文件,源文件等等,在此只说明代码功能的实现逻辑。

c 复制代码
void QueueInit(Queue* pq)
{
	assert(pq);
	pq->head = pq->tail = NULL;
	pq->size = 0;
}

不过在这里还要说明一点,由于在这里我们要修改指针,所以如果正常传参应该要传二级指针,不过我们在这里在此定义一个结构体用来存放我们要用的东西,这样既不用传二级指针使得代码繁琐,也更加方便操作,如下:

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

typedef struct Queue
{
	QNode* head;
	QNode* tail;
	int size;
}Queue;

初始化没什么好说的,过

2.销毁

c 复制代码
void QueueDestroy(Queue* pq)
{
	assert(pq);
	QNode* curr = pq->head;
	while (curr)
	{
		QNode* next = curr->next;
		free(curr);
		curr = next;
	}
	pq->head = pq->tail = NULL;
	pq->size = 0;
}

这里的逻辑较为简单:

  • 用next来保存下一个节点
  • free掉当前节点
  • curr置为下一个节点依次循环

最后把头尾指针置为空即可。

3.插入

c 复制代码
void QueuePush(Queue* pq, QDataType data)
{
	assert(pq);
	QNode* newhead = (QNode*)malloc(sizeof(QNode));
	if (newhead == NULL)
	{
		perror("malloc fail");
		return;
	}
	newhead->next = NULL;
	newhead->val = data;
	//无节点
	if (pq->tail == NULL)
	{
		pq->head = pq->tail = newhead;
	}
	else
	{
		pq->tail->next = newhead;
		pq->tail = newhead;
	}
	pq->size++;
}
  • 首先判断新生成的节点是否有效
  • 接下来把数据的值插入到新生成节点中
  • 如果无节点,那么让头尾指针指向新节点
  • else,让尾指针连着新节点,让尾指针置为指向newhead
  • 最后size++即可

4.删除

c 复制代码
void QueuePop(Queue* pq)
{
	assert(pq);
	assert(pq->size != 0);
	QNode* next = pq->head->next;
	free(pq->head);
	pq->head = next;
	if (pq->head == NULL)
	{
		pq->tail = NULL;
	}
	pq->size--;
}
  • 用next指针保存下一个节点
  • free当前节点
  • 指向下一个节点
  • size--

5.获取队尾和对头数据

c 复制代码
QDataType QueueFront(Queue* pq)
{
	assert(pq);
	assert(pq->size != 0);
	return pq->head->val;
}

QDataType QueueBack(Queue* pq)
{
	assert(pq);
	assert(pq->size != 0);
	return pq->tail->val;
}

很简单,没什么好说的。

6.获取元素个数

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

很简单。

7.判空

c 复制代码
bool QueueEmpty(Queue* pq)
{
	assert(pq);
	return pq->size == 0;
}

同样没什么好说的。

相关推荐
Briue7Rua2 小时前
关于使用Visual Studio编译时产生的编码问题与解决方案
c语言·ide·utf-8·学习·visual studio·gbk
祁同伟.2 小时前
【算法】优选 · 双指针
c++·算法·容器·stl
菜菜小狗的学习笔记2 小时前
数据结构(一)数组和链表
数据结构
项目申报小狂人2 小时前
基于迁移学习与丢弃法的神经网络算法在无人机失移动目标搜索中的应用,含代码
神经网络·算法·迁移学习
stolentime2 小时前
洛谷P15652 [省选联考 2026] 排列游戏 / perm题解
c++·算法·交互·洛谷·联合省选2026
仰泳的熊猫2 小时前
题目1834:蓝桥杯2016年第七届真题-路径之谜
数据结构·c++·算法·蓝桥杯·深度优先·图论
zh路西法2 小时前
【C语言简明教程提纲】(三):字符串与编译预处理
c语言·开发语言
Darkwanderor2 小时前
数据结构——单调栈和单调队列
数据结构·c++·单调栈·单调队列
机器学习之心2 小时前
198种组合算法+优化SVR支持向量机回归+SHAP分析+新数据预测!机器学习可解释分析,强烈安利,粉丝必备!
算法·shap分析·新数据预测·优化svr支持向量机回归