C语言——队列的实现

        队列按照先进先出(FIFO,First In First Out)的原则管理数据。这意味着最先进入队列的元素会被最先移出,类似于排队等候服务的情况。队列通常有两个主要操作:入队(enqueue),将元素添加到队列的尾部;出队(dequeue),从队列的头部移除元素。

        如果用顺序表实现队列,在删除队头数据时,需要后面的数据覆盖前面的数据,比较麻烦,所以采用链表,头删尾插代替出队和入队。但是如果用链表实现的话,寻找队尾入队还需要一直 ->next ,所以干脆我们就记录下头指针和尾指针方便头山尾插。

首先就是定义每个节点的结构体和定义队列的结构体:

struct QueueList {int val;struct QueueList* next;
};
struct Queue {struct QueueList* head;struct QueueList* tail;
};

        这里用QueueNode命名第一个结构体更好,因为我们要记录头尾指针,所以Queue结构体就有头尾两个指针。

接下来是初始化函数和销毁函数;

void QueueInit(struct Queue* list) {list->head = NULL;list->tail = NULL;
}
void QueueDes(struct Queue* list) {while (list->head!=list->tail){struct QueueList* next = list->head->next;free(list->head);list->head = next;}free(list->head);list->head = list->tail = NULL;
}

        初始化函数让list的头指针和尾指针都置为空,销毁函数,如果头尾指针相等,有两种情况,一种是空队列,这时 free(NULL) ,还可以是只有一个元素,头尾指针都指向这个元素,这时free掉,然后指针置空,所以不会有野指针或者free错误的情况。

然后是入队出队函数:

void QueuePushBack(struct Queue* list,int num) {if (list->head == list->tail && list->head == NULL) {list->head = list->tail = malloc(sizeof(struct QueueList));list->head->val = num;list->tail->next = NULL;}else if (list->head == list->tail) {list->tail = malloc(sizeof(struct QueueList));list->tail->val = num;list->tail->next = NULL;list->head->next = list->tail;}else {struct QueueList* tail_pre = list->tail;list->tail = malloc(sizeof(struct QueueList));list->tail->val = num;list->tail->next = NULL;tail_pre->next = list->tail;}
}
int QueueFrontPop(struct Queue* list) {struct QueueList* new_head = list->head->next;int val = list->head->val;free(list->head);list->head = new_head;return val;
}

        对于尾插函数,头尾指针相等时有可能是空队列也有可能是只创建了一个元素,所以要分开讨论,简单逻辑就是让尾节点的next指向新开辟的节点,然后更新尾指针使新开辟的节点变为尾指针,最后让尾节点的next置为NULL。

        对于头删Pop函数,就是先存头节点下一个节点的地址然后free掉头节点,更新头指针,返回数值。

最后是打印函数方便我们观察:

void QueuePrint(struct Queue* list) {struct QueueList* cur = list->head;while (cur != NULL) {printf("%d ", cur->val);cur = cur->next;}
}

这就是文章的全部内容,希望对你有所帮助,如有错误欢迎评论。 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/5878.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python - 3D图表绘制

Pyecharts 和 3D 图表绘制 Pyecharts 是一个用于生成各种图表的 Python 库,它基于 Echarts,支持大量的图表类型,非常适合用于数据分析和可视化。Pyecharts 主要优点是易于使用,可以直接在 Python 环境中绘制富有交互性的图表&…

ES练习项目-酒店搜索

目录 1 需求分析2 酒店搜索和分页2.1 请求和响应分析2.2 定义实体类,接收请求参数的JSON对象2.3 编写controller,接收页面的请求2.4 编写业务实现,利用RestHighLevelClient实现搜索、分页 3. 酒店结果过滤3.1 请求和响应分析3.2 修改请求参数…

【Python快速上手(十)】

目录 Python快速上手(十)Python3 作用域和OS 文件/目录方法Python3 作用域1. 内置作用域(Built-in Scope)2. 全局作用域(Global Scope)3. 嵌套作用域(Enclosing Scope)4. 局部作用域…

Django框架之模型层

一、前期准备 1、测试脚本 当你只是想要测试Django中的某一个py文件内容,那么你可以不用书写前后端交互的形式,而是直接写一个测试脚本即可 这内容其实就是最外部 manage.py 文件中的上面几句话 脚本代码无论是写在应用下的 tests.py文件还是自己新建…

结合创新!频域+时间序列,预测误差降低64.7%

频域时间序列不仅能提供更丰富的信息,还能提高模型性能和预测准确性。对于论文er来说,是个可发挥空间大、可挖掘创新点多的研究方向。 具体来说: 通过将复杂的时间序列数据转换成简单的频率成分,我们可以更容易地捕捉到数据的周期…

【人工智能基础】逻辑回归实验分析

实验环境:anaconda、jutpyter Notebook 实验使用的库:numpy、matplotlib 一、逻辑回归 逻辑回归是一个常用于二分类的分类模型。本质是:假设数据服从这个分布,然后使用极大似然估计做参数的估计。 二、实验准备 引入库、预设值…

Sam Altman:那些我希望有人能早点告诉我的事

大家好,我是木易,一个持续关注AI领域的互联网技术产品经理,国内Top2本科,美国Top10 CS研究生,MBA。我坚信AI是普通人变强的“外挂”,所以创建了“AI信息Gap”这个公众号,专注于分享AI全维度知识…

【跟我学RISC-V】(一)认识RISC-V指令集并搭建实验环境

写在前面 现在计算机的体系架构正是发展得如火如荼的时候,占领桌面端市场的x86架构、占领移动端市场的arm架构、在服务器市场仍有一定地位的mips架构、国产自研的指令集loongarch架构、还有我现在要讲到的新型开源开放的RISC-V指令集架构。 我先说一说我的学习经历…

初始计算机网络

TCP/IP TCP/IP模型 TCP/IP网络模型:对于不同设备之间的通信,就需要网络通信,而设备是多样性的,所以要兼容多种多样的设备,就协商出了一套通用的网络协议。 TCP/IP分层 这个网络协议是分层的,每一层都有…

【MATLAB】GUI初步设计

MATLAB界面设计 前言一、基本步骤1.1 创建GUI文件1.2 界面设计 总结 前言 为了完成图像处理的作业,简直就是生活不易啊 找到一个很棒的教学视频 基于MATLAB的GUI界面设计流程讲解 一、基本步骤 1.1 创建GUI文件 由于在写博文之前我已经创建好文件了,…

SpringBoot+vue实现登录功能

目录 1. vue集成axios 1.1.新建request.js 1.2.新建login.js 2. Login.vue登录页面 2.1.导入login.js 2.2.登录逻辑 3. SpringBoot后台代码 3.1.pom.xm导入hutool工具包 3.2.新建UserPasswordDTO类

文件批量高效管理,批量将PDF类型文件移动到指定文件夹里,实现文件高效管理

文件的管理与整理成为了我们生活中不可或缺的一部分。面对堆积如山的PDF文件,你是否也曾感到手足无措、焦头烂额?现在,有了我们的批量文件管理工具,PDF文件的管理将变得前所未有的高效与简单! 首先,我们要…

拆单算法交易(Algorithmic Trading)

TWAP TWAP交易时间加权平均价格Time Weighted Average Price 模型,是把一个母单的数量平均地分配到一个交易时段上。该模型将交易时间进行均匀分割,并在每个分割节点上将拆分的订单进行提交。例如,可以将某个交易日的交易时间平均分为N 段&am…

compose调用系统分享功能分享图片文件

compose调用系统分享功能图片文件 简介UI界面提供给外部程序的文件访问权限创建FileProvider设置共享文件夹 通用分享工具虚拟机验证结果参考 本系列用于新人安卓基础入门学习笔记,有任何不同的见解欢迎留言 运行环境 jdk17 andriod 34 compose material3 简介 本案…

JavaEE_操作系统之进程(计算机体系,,指令,进程的概念、组成、特性、PCB)

一、冯诺依曼体系(Von Neumann Architecture) 现代的计算机, 大多遵守冯诺依曼体系结构 CPU 中央处理器: 进行算术运算和逻辑判断.存储器: 分为外存和内存, 用于存储数据(使用二进制方式存储)输入设备: 用户给计算机发号施令的设备.输出设备: 计算机个…

Python----列表删除

第一题: 描述 牛牛在各大互联网公司投入了简历,公司的名字通过字符串的形式在一行中输入,请用列表记录。现在牛牛已经确定了第一所公司的HR表露了不录用他的态度,请你使用del函数帮助牛牛从列表中删除第一个元素,然后输出列表。…

Spring-MVC从入门到精通

参数通过网页贯穿技术三层控制第二版 目录(单击可跳转对应目录) 1.SPRINGMVC是什么......................................................... 1 1.1初步认识SPRINGMVC.................................................. 1 1.2框架原理讲解.........…

学习java的static

1.static是什么,用来做什么? static-静态,可以修饰成员变量和成员方法。 2.成员变量按照有无static修饰,分为两种 类变量:有static修饰,属于类,在计算机中,会被类的全部对象所共享…

基于php+mysql+html超市商品管理系统(含论文)

博主介绍: 大家好,本人精通Java、Python、Php、C#、C、C编程语言,同时也熟练掌握微信小程序、Android等技术,能够为大家提供全方位的技术支持和交流。 我有丰富的成品Java、Python、C#毕设项目经验,能够为学生提供各类…

【数据结构-之八大排序(下),冒泡排序,快速排序,挖坑法,归并排序】

🌈个人主页:努力学编程’ ⛅个人推荐:基于java提供的ArrayList实现的扑克牌游戏 |C贪吃蛇详解 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 …