stack 和 queue容器的介绍和使用

1.stack的介绍

1.1stack容器的介绍

stack容器的基本特征和功能我们在数据结构篇就已经详细介绍了,还不了解的uu, 可以移步去看这篇博客哟:

  • 数据结构-栈
  • 数据结构-队列
    栈的示例图
    简单回顾一下,重要的概念其实就是后进先出,栈在实际的工程中有着广泛的用途·,所以在c++的stl库中自然也有它的身影。

1.2 stack的使用

函数说明接口说明
stack构造空的栈
empty检测stack是否为空
size查看栈中元素的数量
top获取栈顶元素
push将元素压入栈中
pop将栈顶元素删除

常用的接口基本是哪个就是上面的这些,现在我们万层下面的练习题来熟练stl库中的stack容器。

1.2.1 最小栈

题目链接
在这里插入图片描述
这道题目非常的特殊,这道题目就是需要我们自己来设计函数接口,来满足题目所需:
这都啊题目需要我们实现一个可以在常数时间内锁定stack中最小元素的Minstack类:

class MinStack {
public:MinStack() {}void push(int val) {}void pop() {}int top() {}int getMin() {}
};/*** Your MinStack object will be instantiated and called as such:* MinStack* obj = new MinStack();* obj->push(val);* obj->pop();* int param_3 = obj->top();* int param_4 = obj->getMin();*/

现在我们要实现下面的接口,其实这道题目也并不复杂,我们只需要定义两个栈


  • 一个栈用于记录此时栈中所有的元素
  • 一个用于记录栈中所有的元素

1.关于怎么来记录此时容器中最小的元素,我们就只需要在元素入栈的时候进行比较就可以实现
2. 只要遇到比记录最小值栈的栈顶元素小的元素,我们就直接让其成为栈顶

有了基本的思路后大家可以自己尝试一下这道题目 😛:
好了,相信大家已经做出来了,现在我们就来展示一下答案吧:🌈

class MinStack {
public:MinStack() {}void push(int val) {//注意:这里一定是小于等于,在st种可能存在多个最小值if (_min.empty() || val <= _min.top()) _min.push(val);st.push(val);}void pop() {if (st.top() == _min.top()) _min.pop();st.pop();}int top() {return st.top();}int getMin() {return _min.top();}
private:stack<int> st;stack<int> _min;
};

在这里插入图片描述

1.2.2 栈的弹出压入序列

题目链接
在这里插入图片描述
这都题目就是需要我们根据栈的后进先出的特性来进行判断,其实在了解了stack的基本特性后也是十分的简单的, 接下来我就直接展示代码了:

class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param pushV int整型vector * @param popV int整型vector * @return bool布尔型*/bool IsPopOrder(vector<int>& pushV, vector<int>& popV) {// write code hereif (pushV.size() != popV.size() ) return false;int n = pushV.size();int out = 0, in = 0;stack<int> s;while (out < n){while (s.empty() || s.top() != popV[out]){if (out < n)s.push(pushV[in++]);else return false;}s.pop();out++;}if (!s.empty()) return false;;return true;}
};

完成了上面的题目相信大家都已经对stack容器的使用很熟悉了,那我们就进入queue的学习了 😛

2. queue容器的介绍和学习

在这里插入图片描述
队列(queue)系那个寻大家爱都已对此十分的熟悉了,大家在学习之前也可以先来阅读以下下面的这篇文档哈 🌈 🌈
和stack一样,在stl中我们也可以直接使用他提供的众多接口,下面就是我们常用的一些接口:

2.1 queue接口介绍

函数声明接口说明
queue构造空的队列
empty检测队列是否为空,是返回true, 否则返回false
size返回队列中的元素
front返回对头元素的引用
back返回队尾元素的引用
push在队尾将元素val插入队列
pop将对头元素出队列

2.2 queue相关的题目

为了熟悉上那面的接口,我们还是通过练习下面的题目来巩固我们的学习:

2.2.1 用队列实现栈

题目链接

在这里插入图片描述
这道题目还是十分简单的,我们知道了 stack 和 queue对于数据的存取顺序的区别,需要使得后面插入的元素在队列的前端
现在大家可以在得到提示后可以先舱室自己做一下哈,下面我就直接展示代码了:

class MyStack {
public:
queue<int> qu;MyStack() {}void push(int x) {int n = qu.size();qu.push(x);while (n--){int t = qu.front();qu.pop();qu.push(t);}}int pop(){int a = qu.front();qu.pop();return a;}int top() {return qu.front();}bool empty() {return qu.empty();}
};/*** Your MyStack object will be instantiated and called as such:* MyStack* obj = new MyStack();* obj->push(x);* int param_2 = obj->pop();* int param_3 = obj->top();* bool param_4 = obj->empty();*/

在这里插入图片描述

3. priority_queue的介绍和使用

3.1priority_queue的介绍

介绍文档
介绍:

  1. 优先队列是一种容器适配器,更具严格的弱排序标准,他的第一个元素总是它所包含元素的中的最大值
  2. 类似于堆, 在堆中随时插入元素,并且只能检索最大的堆中元素 (优先队列中位于顶部的元素)
  3. 优先队列被实现为容器适配器,容器适配器即将特定的容器封装为其底层的容器类,queue提供的一组特定的成员函数来访问其元素。元素从特定的容器“尾部”弹出,其被称为优先队列的顶部
  4. 底层的容器可以是任何标准的类模板,也可以是其他特定的设计类模板。容器应该可以通过随机访问迭代器访问,并支持以下的操作:
    • empty():检测容器是否为空
    • size():返回容器中有效元素个数
    • front():返回容器中第一个元素的引用
    • push_back():在容器尾部插入元素
    • pop_back():删除容器尾部元素
  5. 标准容器类vector和deque满足这些需求。默认情况下,如果没有为特定的priority_queue
    类实例化指定容器类,则使用vector。
  6. 需要支持随机访问迭代器,以便始终在内部保持堆结构。容器适配器通过在需要时自动调用
    算法函数make_heap、push_heap和pop_heap来自动完成此操作。

3.2 priority_queue的使用

优先级队列默认使用vector作为其底层存储数据的容器,在vector上又使用了堆算法将vector中
元素构造成堆的结构,因此priority_queue就是堆,所有需要用到堆的位置,都可以考虑使用
priority_queue注意:默认情况下priority_queue是大堆

3.2.1 常用接口的介绍

函数声明接口说明
priority_queue()/priority_queue(first,last)构造一个空的优先级队列
empty( )检测优先级队列是否为空,是返回true,否则返回false
top( )返回优先级队列中最大(最小元素),即堆顶元素
push(x)在优先级队列中插入元素x
pop()删除优先级队列中最大(最小)元素,即堆顶元素

注意:在默认情况下,priority_queue就是大堆, 想要将其改为小堆需要一个greater<T>的类模板

#include <vector>
#include <queue>
#include<iostream>
using namespace std;
void TestPriorityQueue()
{// 默认情况下,创建的是大堆,其底层按照小于号比较vector<int> v{3, 2, 7, 6, 0, 4, 1, 9, 8, 5};priority_queue<int> q1;for (auto &e : v)q1.push(e);cout << q1.top() << endl;// 如果要创建小堆,将第三个模板参数换成greater比较方式priority_queue<int, vector<int>, greater<int>>q2(v.begin(), v.end());cout << q2.top() << endl;
}int main()
{TestPriorityQueue();return 0;
}

总而言之,priority_queue就像是我们再数据结构中学到的堆的具体应用,现在我们就还是通过题目来熟练使用stl的优先队列吧 ✈️

3.3 priority_queue在OJ题目中的应用

数组中的第K个大的元素

在这里插入图片描述
题目中要求我们使用O(N)的时间复杂度来解决这个问题,因此我们不能直接对数组进行排序,然后直接找对应位置的元素,因为快速排序的时间复杂度是Nlog(N)
因此我们就需要用到我们刚学习的容器来解决这个问题了,其实也十分的简单,大家:自己尝试着做

class Solution {
public:int findKthLargest(vector<int>& nums, int k) {priority_queue<int, vector<int>, greater<int>> q;for (auto& x : nums){q.push(x);if (q.size() > k) q.pop();}return q.top();}
};

这样我们看就可以以O(N)的时间复杂度完成这道题目了!!
在这里插入图片描述
注: 使用priority_queue不是这道题最优的解法,大家可以下去自己探索哈 😛

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

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

相关文章

python:洛伦兹变换

洛伦兹变换&#xff08;Lorentz transformations&#xff09;是相对论中的一个重要概念&#xff0c;特别是在讨论时空的变换时非常重要。在四维时空的背景下&#xff0c;洛伦兹变换描述了在不同惯性参考系之间如何变换时间和空间坐标。在狭义相对论中&#xff0c;洛伦兹变换通常…

DIY QMK量子键盘

最近放假了&#xff0c;趁这个空余在做一个分支项目&#xff0c;一款机械键盘&#xff0c;量子键盘取自固件名称QMK&#xff08;Quantum Mechanical Keyboard&#xff09;。 键盘作为计算机或其他电子设备的重要输入设备之一&#xff0c;通过将按键的物理动作转换为数字信号&am…

【Unity3D】aab包太大无法上传Google问题

目录 一、勾选Split Application Binary&#xff0c;Unity直接打aab包 勾选Split Application Binary选项的影响 不勾选Split Application Binary选项的影响 总结 2、导出Android工程打包aab 一、勾选Split Application Binary&#xff0c;Unity直接打aab包 超出150MB部分…

DeepSeek助力学术文献搜索!

搜集文献 宝子们如果是第一次发表学术论文&#xff0c;论文往往是会署名多个作者。在这种情况下&#xff0c;即便成功发表了论文&#xff0c;独立撰作或主导写作的挑战仍旧存在。那么&#xff0c;怎样才能独立地完成一篇属于自己的学术论文呢&#xff1f;对于初次尝试学术论文…

【时时三省】(C语言基础)文件的随机读写

山不在高&#xff0c;有仙则名。水不在深&#xff0c;有龙则灵。 ----CSDN 时时三省 fseek 根据文件指针的位置和偏移量来定位文件指针 示例&#xff1a; 这个输出的就是ade seek&#xff3f;cur的意思是从当前偏移量 2就是从a往后偏移两个就是d 偏移量 SEEK&#xff3f;CUR…

Python-基于PyQt5,json和playsound的通用闹钟

前言&#xff1a;刚刚结束2024年秋季学期的学习&#xff0c;接下来我们继续来学习PyQt5。由于之前我们已经学习了PyQt5以及PyUIC,Pyrcc和QtDesigner的安装&#xff0c;配置。所以接下来我们一起深入PyQt5&#xff0c;学习如何利用PyQt5进行实际开发-基于PyQt5&#xff0c;json和…

数据结构课程设计(三)构建决策树

3 决策树 3.1 需求规格说明 【问题描述】 ID3算法是一种贪心算法&#xff0c;用来构造决策树。ID3算法起源于概念学习系统&#xff08;CLS&#xff09;&#xff0c;以信息熵的下降速度为选取测试属性的标准&#xff0c;即在每个节点选取还尚未被用来划分的具有最高信息增益的…

2024收尾工作

目录 开场白 栈与队列 LeetCode232. 用栈实现队列 LeetCode225. 用队列实现栈 LeetCode102. 二叉树的层序遍历 LeetCode103. 二叉树的锯齿形层序遍历 堆&#xff08;优先级队列&#xff09; 堆排序 LeetCode215. 数组中的第 k 个最大元素 总结 开场白 今天是除夕&…

纯css实现div宽度可调整

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><title>纯css实现div尺寸可调整</title><style…

浅谈Linux的发展

目录 1.Linux背景 1.1 发展史 UNIX发展的历史 1.2开源 1.3官网 1.4.企业应用现状 1.5.发行版本 1.6 os概念&#xff0c;定位 1.Linux背景 1.1 发展史 学习Linux系统编程&#xff0c;你可能要问Linux从哪里来&#xff1f;它是怎么发展的&#xff1f;在这里简要介绍Linux的发展史…

四层网络模型

互联网由终端主机、链路和路由器组成&#xff0c;数据通过逐跳的方式&#xff0c;依次经过每条链路进行传输。 网络层的工作是将数据包从源端到目的端&#xff0c;跨越整个互联网。 网络层的数据包称为数据报。网络将数据报交给链路层&#xff0c;指示它通过第一条链路发送数据…

世上本没有路,只有“场”et“Bravo”

楔子&#xff1a;电气本科“工程电磁场”电气研究生课程“高等电磁场分析”和“电磁兼容”自学”天线“、“通信原理”、“射频电路”、“微波理论”等课程 文章目录 前言零、学习历程一、Maxwells equations1.James Clerk Maxwell2.自由空间中传播的电磁波3.边界条件和有限时域…

python学opencv|读取图像(四十六)使用cv2.bitwise_or()函数实现图像按位或运算

【0】基础定义 按位与运算&#xff1a;全1取1&#xff0c;其余取0。按位或运算&#xff1a;全0取0&#xff0c;其余取1。 【1】引言 前序学习进程中&#xff0c;已经对图像按位与计算进行了详细探究&#xff0c;相关文章链接如下&#xff1a; python学opencv|读取图像&…

如何把obsidian的md文档导出成图片,并加上文档属性

上篇关于这个插件PKMer_Obsidian 插件&#xff1a;Export Image plugin 一键将笔记转换为图片分享的文章 如何把obsidian的md文档导出成图片&#xff0c;并加上水印-CSDN博客 如何导出图片的时候让文档属性也显示出来&#xff0c;啊啊&#xff0c;这个功能找了一晚上&#xf…

MATLAB算法实战应用案例精讲-【数模应用】方向梯度直方图(HOG)(附python代码实现)

目录 前言 算法原理 特征描述 什么是方向梯度直方图? 算法思想: 实现方法: 性能提高: HOG特征提取 直方图阈值化 直方图均衡化 算法步骤: 算法流程 1. 图像预处理 2. 计算图像梯度 3. 计算梯度直方图 4. 图像HOG特征向量 直方图反向投影 其它类型图像直…

CycleGAN模型解读(附源码+论文)

CycleGAN 论文链接&#xff1a;Unpaired Image-to-Image Translation using Cycle-Consistent Adversarial Networks 官方链接&#xff1a;pytorch-CycleGAN-and-pix2pix 老规矩&#xff0c;先看看效果 总体流程 先简单过一遍流程&#xff0c;细节在代码里说。CycleGAN有…

ue5 GAS制作一个技能,技能冷却,给剑添加碰撞预设,打击敌人

总结&#xff1a; 新建文件夹 ability 取名BP_BaseAbility 新建一个技能GAB_Melee 上面技能GAB_Melee和技能基类BP_BaseAbility 进入技能GAB_Melee&#xff0c;添加打印火云掌 给这个技能添加标签 点这个号 这样命名&#xff0c;小心这个点&#xff08;.&#xff09…

工作总结:git篇

文章目录 前言基础Gerrit1.克隆2.新建本地分支和checkout3.添加到暂存区新增文件到暂存区修改已经添加到暂存区的文件取消添加到暂存区的文件 4.提交到本地仓库在不重复提交的情况下&#xff0c;修改本次提交 5.提交到远程仓库6.评审其他辅助命令 前言 目前也算是工作一段时间…

ESP32 I2S音频总线学习笔记(二):I2S读取INMP441音频数据

简介 在这个系列的上一篇文章中&#xff0c;我们介绍了ESP32 I2S音频总线的相关知识&#xff0c;简要了解了什么是I2S总线、它的通信格式&#xff0c;以及相关的底层API函数。没有看过上篇文章的可以点击文章进行回顾&#xff1a; ESP32 I2S音频总线学习笔记&#xff08;一&a…

(学习总结21)C++11 异常与智能指针

C11 异常与智能指针 异常异常的概念异常的抛出和捕获栈展开查找匹配的处理代码异常重新抛出异常安全问题异常规范标准库的异常 智能指针RAII 和智能指针的设计思路智能指针的使用场景分析C标准库智能指针的使用weak_ptr 和 shared_ptr循环引用weak_ptrshared_ptr 循环引用问题 …