数据结构(长期更新)第8讲:队列

数据结构(长期更新)

第8讲:队列

++跟着潼心走,轻松拿捏C语言,困惑通通走,一去不回头~欢迎开始今天的学++ ++习内容,你的支持就是博主最大的动力++ 。博主主页:潼心1412o-CSDN博客


目录

数据结构(长期更新)

第8讲:队列

[8.1 前言](#8.1 前言)

[8.2 概念和性质](#8.2 概念和性质)

[8.3 实现方式/底层结构](#8.3 实现方式/底层结构)

[8.4 基本操作](#8.4 基本操作)

[8.5 用队列实现栈](#8.5 用队列实现栈)

[8.6 用栈实现队列](#8.6 用栈实现队列)


8.1 前言

上节课我们学习了栈,这是一种特殊的线性表,只能在一端(即栈顶)对数据进行操作,底层是通过数组实现的,而今天我们要学习的是队列,和栈完全相反,可以进行类比学习。还等什么,gogogo,出发喽~

8.2 概念和性质

队列:只允许在一端进行插入,一段进行删除的线性表。

出队列------队头:删除端

入队列------队尾:插入端

我们可以联想日常生活中排队的情景方便记忆

性质:先进先出即 FIRST IN FIRST OUT(FIFO)

8.3 实现方式/底层结构

底层结构为链表

原因:虽然数组和链表都有一端时间复杂度为O(N),一端为O(1),但是我们知道链表是可以进行优化的,比如增加一个尾指针,就可以大大提高运行效率。但是数组的头删就不太行,效率很低。所以优先选择链表。

8.4 基本操作

queue.h

初始化

创建新结点

入队---队尾

出队---队头

销毁

8.5 用队列实现栈

https://leetcode.cn/problems/implement-stack-using-queues/description/

思路分析:如何实现用两个队列实现栈?

入栈:往非空队列尾插入数据

出栈:将前n-1个数据出队列,入另一个队列,pop第一个队列队尾元素

取栈顶元素:取非空队列队尾元素

8.6 用栈实现队列

https://leetcode.cn/problems/implement-queue-using-stacks/description/

思路分析:创建两个栈,一个专门用于存放数据PushST,一个专门用于出数据PopST

入队:往PushST里面入栈

出队:只要PopST不为空,就出栈;为空先把PushST里面的数据倒进PopST,再出栈

取队头:逻辑同出队,但是只取不删除


++好了今天的学习内容就到这里啦,谢谢你的陪伴,我是潼心,下次再见~如果这篇文章对你有帮助的话。请务必给主播一个一键三连,球球了,这对主播很重要~++

博主主页:潼心1412o-CSDN博客

相关推荐
Wei&Yan4 分钟前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
long31643 分钟前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
张张努力变强3 小时前
C++ STL string 类:常用接口 + auto + 范围 for全攻略,字符串操作效率拉满
开发语言·数据结构·c++·算法·stl
wWYy.3 小时前
数组快排 链表归并
数据结构·链表
李斯啦果4 小时前
【PTA】L1-019 谁先倒
数据结构·算法
Mr Xu_19 小时前
告别硬编码:前端项目中配置驱动的实战优化指南
前端·javascript·数据结构
czxyvX19 小时前
017-AVL树(C++实现)
开发语言·数据结构·c++
数智工坊19 小时前
【数据结构-队列】3.2 队列的顺序-链式实现-双端队列
数据结构
elseif12320 小时前
【C++】并查集&家谱树
开发语言·数据结构·c++·算法·图论
徐小夕@趣谈前端20 小时前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6