IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> C语言数据结构-队列 -> 正文阅读

[数据结构与算法]C语言数据结构-队列

队列的概念及结构

队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出FIFO(First In First Out) 入队列:进行插入操作的一端称为队尾 出队列:进行删除操作的一端称为队头
在这里插入图片描述

队列的链式存储实现

采用单链表来实现队列的链式结构,设置一个头指针和尾指针。通常将队头指针和队尾指针封装在一个结构体中,并将该结构体类型重新命名为链队列类型。

typedef int QDataType;
typedef struct QListNode
{
	struct QListNode *next;//数据域
	QDataType data;//指针域
}QNode;

typedef struct Queue
{
	QNode *phead;//头指针
	QNode *ptail;//尾指针
}Queue;

在这里插入图片描述

队列初始化

初始化比较简单

// 初始化队列
void QueueInit(Queue* pq)
{
	assert(pq);
	pq->front = NULL;
	pq->rear = NULL;

}

重点:入队列

在这里插入图片描述
入队列就是尾插,需要注意空队列。

// 队尾入队列
void QueuePush(Queue* pq, QDataType x)
{
	assert(pq);
	//开辟新结点
	QNode *newnode = (QNode *)malloc(sizeof(QNode));
	//判断是否开辟成功
	if (newnode == NULL)
	{
		printf("malloc fail");
		exit(-1);
	}
	newnode->data = x;
	newnode->next = NULL;
	//队列为空时
	if (pq->front == NULL)
	{
		pq->front = newnode;
		pq->rear = newnode;
	}
	else
	{
		pq->rear->next = newnode;
		pq->rear = newnode;
	}
}

打个断点调试
在这里插入图片描述
1,2,3就已经入队了。

重点:出队列

头删,保存下一个结点,free当前结点
在这里插入图片描述
错误的写法
在这里插入图片描述
从调试看出rear还在指向结点,虽然3已经free,但rear还在指向那里的空间。这个坑要单独处理。

void QueuePop(Queue* pq)
{
	assert(pq);
	//队列为空时就不能继续出了
	assert(!QueueEmpty(pq));

	if (pq->front->next == NULL)
	{
		free(pq->front);
		pq->front = pq->rear = NULL;
	}
	else
	{
		Queue* next = pq->front->next;
		free(pq->front);
		pq->front = next;
	}
}

获取队列头部元素

注意空队列

// 获取队列头部元素
QDataType QueueFront(Queue* pq)
{
	assert(pq);
	assert(!QueueEmpty(pq));
	return pq->front->data;
}

获取队列队尾元素

跟上面的一样

QDataType QueueBack(Queue* pq)
{
	assert(pq);
	assert(!QueueEmpty(pq));
	return pq->rear->data;
}

检测队列是否为空

// 检测队列是否为空,如果为空返回非零结果,如果非空返回0
int QueueEmpty(Queue* pq)
{
	assert(pq);
	return pq->front == NULL && pq->rear == NULL;
}

队列的销毁

// 销毁队列
void QueueDestroy(Queue* pq)
{
	assert(pq);
	QNode *cur = pq->front;
	while (cur)
	{
		Queue *next = cur->next;
		free(cur);
		cur = next;
	}
	pq->front = pq->rear = NULL;
}

在这里插入图片描述

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-09-30 12:11:23  更:2021-09-30 12:11:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/17 13:51:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码