队列的实现(使用C语言)

完整代码链接: DataStructure: 基本数据结构的实现。 (gitee.com)

目录

一、队列的概念:

二、队列的实现:

使用链表实现队列:

1.结构体设计:

2.初始化:

3.销毁:

4.入队:

5.出队:

6.获取队头数据:

7.获取队尾数据:

8.判空:

9.查看队列长度:


一、队列的概念:

队列 是一种特殊的线性表,其只允许在一端执行插入数据操作,在另一端执行删除数据操作 。队列中的数据元素遵循先进先出 FIFO(First In First Out) 原则**。**

入队列 :进行插入操作的一端称为队尾

出队列 :进行删除操作的一端称为队头

二、队列的实现:

同栈一样,数组和链表都可以实现队列。但是,使用链表的结构实现队列会更优一些,因为如果使用数组的结构,出队列在数组头上出数据,效率会比较低。

使用链表实现队列:

1.结构体设计:

objectivec 复制代码
typedef int QueueDataType;

typedef struct QueueNode//队列里单个结点的设计
{
	struct QueueNode* _next;
	QueueDataType _data;
}QueueNode;

typedef struct Queue//队列结构体的设计
{
	QueueNode* _head;
	QueueNode* _tail;
}Queue;

2.初始化:

objectivec 复制代码
void QueueInit(Queue* pq)
{
	assert(pq);
    //队列内还没有数据
	pq->_head = NULL;
	pq->_tail = NULL;
}

3.销毁:

objectivec 复制代码
void QueueDestory(Queue* pq)
{
	assert(pq);
	QueueDataType* tmp = NULL;//指向要被释放的结点
	while (pq->_head != NULL)
	{
		tmp = pq->_head;
		pq->_head = pq->_head->_next;
		free(tmp);
	}
	pq->_tail = NULL;//当队列里所有结点都被释放时,pq->_tail所指向的结点也被释放了
}

4.入队:

objectivec 复制代码
void QueuePush(Queue* pq, QueueDataType x)
{
	assert(pq);
	QueueNode* newNode = (QueueNode*)malloc(sizeof(QueueNode));
	if (newNode == NULL)
	{
		printf("内存不足\n");
		exit(-1);
	}
	newNode->_data = x;
	newNode->_next = NULL;
	if (pq->_head == NULL)//队列里没有数据
    {
		pq->_head = pq->_tail = newNode;
	}
	else
	{
		pq->_tail->_next = newNode;
		pq->_tail = newNode;
	}
}

5.出队:

objectivec 复制代码
void QueuePop(Queue* pq)
{
	assert(pq);
	assert(pq->_head);
	QueueNode* next = pq->_head->_next;
	free(pq->_head);
	pq->_head = next;
	if (pq->_head == NULL)//当没有了数据
	{
		pq->_tail = NULL;
	}
}

6.获取队头数据:

objectivec 复制代码
QueueDataType QueueFront(Queue* pq)
{
	assert(pq);
	assert(pq->_head);
	return pq->_head->_data;
}

7.获取队尾数据:

objectivec 复制代码
QueueDataType QueueBack(Queue* pq)
{
	assert(pq);
	assert(pq->_tail);
	return pq->_tail->_data;
}

8.判空:

objectivec 复制代码
bool QueueEmpty(Queue* pq)
{
	assert(pq);
	return pq->_head == NULL ? 1 : 0;
}

9.查看队列长度:

objectivec 复制代码
int QueueSize(Queue* pq)
{
	assert(pq);
	QueueNode* cur = pq->_head;
	int size = 0;
	while (cur != NULL)
	{
		size++;
		cur = cur->_next;
	}
	return size;
}
相关推荐
一个爱编程的人7 小时前
一个数是不是素数
数据结构·算法
忡黑梨7 小时前
eNSP_从直连到BGP全网互通
c语言·网络·数据结构·python·算法·网络安全
地球资源数据云8 小时前
1900-2023年中国物种分布点位矢量数据集
大数据·数据结构·数据库·数据仓库·人工智能
AI人工智能+电脑小能手8 小时前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index
牢姐与蒯8 小时前
cpp数据结构之map
数据结构
故事和你918 小时前
洛谷-算法2-3-分治与倍增5
开发语言·数据结构·c++·算法·动态规划·图论
北顾笙9809 小时前
day37-数据结构力扣
数据结构·算法·leetcode
liuyao_xianhui10 小时前
进程概念与进程状态_Linux
linux·运维·服务器·数据结构·c++·哈希算法·宽度优先
如君愿10 小时前
考研复习 Day 26 | 习题--计算机网络第三章(数据链路层 下)、数据结构 多维数组与广义表
数据结构·计算机网络·考研·记录考研
bqq1986102610 小时前
MySQL分库分表
数据结构·mysql