【C++】STL----stack和queue常见用法

news2024/11/14 14:12:55

🔥个人主页🔥:孤寂大仙V
🌈收录专栏🌈:C++从小白到高手
🌹往期回顾🌹:【C++】list常见用法
🔖 流水不争,争的是滔滔不息。

文章目录

  • 一、stack的介绍
    • stack的使用
  • 二、queue的介绍
    • queue的使用
  • 三、优先级队列(priority_queue)的介绍
    • 优先级队列的使用


一、stack的介绍

在 C++ 中,stack 是一种标准模板库(STL)提供的容器适配器,它遵循“后进先出”(LIFO, Last In First Out)的原则。这意味着最后插入的元素最先被访问。stack 是通过底层容器(如 vector 或 deque)实现的。
在这里插入图片描述

在这里插入图片描述

stack的使用

在这里插入图片描述
在这里插入图片描述
构造空的栈

stack<int> s1();

在这里插入图片描述
检测stack是否为空

stack<int> s2;
s2.push(1);
s2.push(2);
s2.push(3);
s2.push(4);
s2.push(5);

if (s2.empty())
{
	cout << "k" << endl;
}
else
{
	cout << "m" << endl;
}

在这里插入图片描述
返回stck中元素的个数

stack<int> s3;
s3.push(1);
s3.push(2);
s3.push(3);
s3.push(4);
s3.push(5);

cout << s3.size() << endl;

在这里插入图片描述
返回栈顶元素的引用

stack<int> s4;
s4.push(1);
s4.push(2);
s4.push(3);
s4.push(4);
s4.push(5);

cout << s4.top() << endl;

在这里插入图片描述
将元素val压入stack中
前面的演示代码都是用的push

stack<int> s4;
s4.push(1);
s4.push(2);
s4.push(3);
s4.push(4);
s4.push(5);

cout << s4.top() << endl;

将stack中尾部的元素弹出

stack<int> s5;
s5.push(1);
s5.push(2);
s5.push(3);
s5.push(4);
s5.push(5);

s5.pop();

cout << s5.size() << endl;

弹出栈中的最后一个元素后,这个栈就有四个元素了。
在这里插入图片描述

二、queue的介绍

在C++中,queue 是一个非常有用的容器适配器,它提供了一种先进先出(FIFO, First In First Out)的数据结构。queue 是一种线性数据结构,其中元素的添加(enqueue)发生在队列的一端(称为队尾),而元素的移除(dequeue)发生在另一端(称为队首)。这种特性使得 queue 成为处理一系列需要按顺序处理的任务或事件的理想选择。
在这里插入图片描述

queue的使用

在这里插入图片描述
在这里插入图片描述
构造空的队列

queue<int> q1();

在这里插入图片描述
判断队列是否为空,是返回true,否返回false

queue<int> s7;
s7.push(1);
s7.push(2);
s7.push(3);
s7.push(4);
s7.push(5);

cout << s7.empty() << endl;

在这里插入图片描述
返回队列中有效元素的个数

queue<int> s8;
s8.push(1);
s8.push(2);
s8.push(3);
s8.push(4);
s8.push(5);

cout << s8.size() << endl;

在这里插入图片描述
返回对头元素的引用
返回队尾元素的引用

queue<int> s9;
s9.push(1);
s9.push(2);
s9.push(3);
s9.push(4);
s9.push(5);

cout << s9.front() << endl;
cout << s9.back() << endl;

在这里插入图片描述
在队尾将元素val入队列

queue<int> s9;
s9.push(1);
s9.push(2);
s9.push(3);
s9.push(4);
s9.push(5);

将对头元素出队列

queue<int> s10;
s10.push(1);
s10.push(2);
s10.push(3);
s10.push(4);
s10.push(5);
cout << s10.size() << endl;

s10.pop();

cout << s10.size() << endl;

出队列前队列里有5个元素,出队列后队列里还有4个元素。
在这里插入图片描述

三、优先级队列(priority_queue)的介绍

优先级队列(Priority Queue)是一种特殊的队列数据结构,它在普通队列的基础上增加了元素优先级的概念。在优先级队列中,每个元素都有一个优先级标签与之关联,优先级最高的元素会最先被移除(出队)。这种数据结构广泛应用于多种算法和场景中,比如任务调度、事件处理、堆排序等。

其实优先级队列就是数据结构中的堆!

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

优先级队列的使用

在这里插入图片描述
在这里插入图片描述
构造一个空的优先级队列

vector<int> v{ 2,5,3,7,9,10,4,6,8,1 };
priority_queue<int> q1;
for (auto e : v)
{
	q1.push(e);
}
cout << q1.top() << endl;//默认建大堆	

这段代码里面的q1就是构造的空的优先级队列。然后把vector容器中的元素放进去。
在这里插入图片描述
检测优先级队列是否为空,是返回true,否返回false。

vector<int> v{ 2,5,3,7,9,10,4,6,8,1 };
priority_queue<int> q2;
for (auto e : v)
{
	q2.push(e);
}

cout << q2.empty() << endl;

在这里插入图片描述
返回优先级队列中最大元素,即堆顶元素

vector<int> v{ 2,5,3,7,9,10,4,6,8,1 };
priority_queue<int> q1;
for (auto e : v)
{
	q1.push(e);
}
cout << q1.top() << endl;//默认建大堆	

在这里插入图片描述
在优先级队列中插入元素x

vector<int> v{ 2,5,3,7,9,10,4,6,8,1 };
priority_queue<int> q1;
for (auto e : v)
{
	q1.push(e);
}
cout << q1.top() << endl;//默认建大堆	

把vector容器中的元素放入优先级队列中。
在这里插入图片描述
删除优先级队列中最大元素,即堆顶元素

vector<int> v{ 2,5,3,7,9,10,4,6,8,1 };
priority_queue<int> q3;
for (auto e : v)
{
	q3.push(e);
}

q3.pop();

cout << q3.top() << endl;

删除堆顶元素之前,堆顶元素为10,删除堆顶元素之后优先级列表重新调整,堆顶元素为9.
在这里插入图片描述

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

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

相关文章

KTH7823——16 位高精度低延时霍尔磁编码器可编程 ABZ 和 PWM 输出模式角度传感器

KTH7823 是一款高精度绝对角度霍尔传感器芯片&#xff0c;最高 16 位分辨率绝对角度输出&#xff0c;可 实现在轴向和离轴场合下的无接触式磁场角度测量。不论转速范围在 0-120000rpm 之间&#xff0c; KTH7823 都能快速准确地输出角度信息&#xff0c;适用于需要精准角…

7个提升网站分页体验的 CSS 和 JavaScript 代码片段

文章目录 前言正文1.简洁直观的悬停分页效果2.实时显示页码的分页3.适合响应式设计的多功能分页4.专为移动设备优化的分页5.无数字的极简分页设计6.触屏友好的分页7.结合无限滚动与分页的设计 总结 前言 分页是内容丰富的网站中不可缺少的导航工具&#xff0c;能帮助用户更轻松…

鱼类计数与识别系统源码分享

鱼类计数与识别检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer V…

【C语言】⾃定义类型:联合和枚举

⾃定义类型&#xff1a;联合和枚举 1. 联合体1.1 联合体类型的声明1.2 联合体的特点1.3 相同成员的结构体和联合体对⽐1.4 联合体⼤⼩的计算1.5 联合的⼀个练习 2. 枚举类型2.1 枚举类型的声明2.2 枚举类型的优点2.3 枚举类型的使⽤ 1. 联合体 1.1 联合体类型的声明 像结构体…

滚珠花键与滚珠丝杆的区别与应用

在机械工业中&#xff0c;经常使用滚珠花键这种传动元件&#xff0c;人们经常拿它与滚珠丝杆相比较&#xff0c;甚至与之混淆。事实上&#xff0c;它们是不同的&#xff0c;滚珠花键和滚珠丝杆在机械传动领域中各有其独特的作用和特点。那么&#xff0c;两者之间的区别是什么呢…

list(二) (list模拟实现)

首先进行大框架 先写基本的结点类 有data next prev template<class T>class ListNode//或者使用struct 就不用在写public声明公有{public://这里不仅仅是成员函数 成员变量也要公有化 ListNode<T>* _next;ListNode<T>* _prev;T _data;}之后是链表list类…

OpenHarmony(鸿蒙南向开发)——小型系统内核(LiteOS-A)【时间管理】

往期知识点记录&#xff1a; 鸿蒙&#xff08;HarmonyOS&#xff09;应用层开发&#xff08;北向&#xff09;知识点汇总 鸿蒙&#xff08;OpenHarmony&#xff09;南向开发保姆级知识点汇总~ 子系统开发内核 轻量系统内核&#xff08;LiteOS-M&#xff09; 轻量系统内核&#…

围剿Model Y,小米SUV也来拼刺刀了

文 | AUTO芯球 作者 | 雷慢 马斯克真是被小米雷军盯上了&#xff0c; 前面小米SU7死磕Model 3&#xff0c; 现在小米SUV又来打Model Y了&#xff0c; 别不信啊&#xff0c;就刚刚&#xff0c;小米SUV出现了最大的曝光&#xff0c; 外观谍照&#xff0c;内饰中控台都曝光了…

RflySim工具链常见问题答疑

1. RflySim结合硬件能不能实现无人机颜色巡线呢&#xff1f; 可以&#xff0c;内置有一个通过相机识别来攻击小球的实验&#xff0c;可见&#xff1a;【RflySim安装路径】\RflySimAPIs\8.RflySimVision\1.BasicExps\1-VisionCtrlDemos\e3_ShootBall&#xff0c;不过要想实现无人…

Linux 进程3

进程地址空间 CPU读取数据都需要地址&#xff0c;在计算机中所有东西都是一种数据&#xff0c;包括我们的进程。 这是一个进程空间示意图&#xff0c;操作系统通过task_struct结构体链表来管理每一个进程&#xff0c;结构体里面有一个指针指向操作系统为进程开辟的一段空间&am…

博导团队指导、解读实验结果、SCI论文润色

表观组&#xff1a; DAP-seq:转录因子-DNA互作研究工具 ATAC-seq :染色质开放程度研究工具 H3K4me3 ChIP-seq:组蛋白甲基化修饰工具 BS-seq :DNA甲基化研究工具 H3K27ac ChIP-seq:组蛋白乙酰化修饰研究工具 Cut&Tag:转录因子研究工具 ChIP-seq:转录因子-DNA互作工具 互作组…

HTTP 教程

HTTP/HTTPS 简介 HTTP&#xff08;Hypertext Transfer Protocol&#xff0c;超文本传输协议&#xff09;和 HTTPS&#xff08;Hypertext Transfer Protocol Secure&#xff0c;超文本传输安全协议&#xff09;是用于在网络中传输信息的两种主要协议。它们定义了客户端和服务器…

PDF样本册如何分享到朋友圈

​想象一下&#xff0c;你刚刚参加了一场行业盛会&#xff0c;获取了一份包含最新行业动态、优秀案例的PDF样本册。你迫不及待地想要分享给身边的朋友&#xff0c;与他们共同学习、探讨。然而&#xff0c;传统的分享方式要么依赖纸质版&#xff0c;要么通过电子邮件&#xff0c…

C++模拟实现list:list、list类的初始化和尾插、list的迭代器的基本实现、list的完整实现、测试、整个list类等的介绍

文章目录 前言一、list二、list类的初始化和尾插三、list的迭代器的基本实现四、list的完整实现五、测试六、整个list类总结 前言 C模拟实现list&#xff1a;list、list类的初始化和尾插、list的迭代器的基本实现、list的完整实现、测试、整个list类等的介绍 一、list list本…

LeetCode讲解篇之220. 存在重复元素 III

文章目录 题目描述题解思路题解代码 题目描述 题解思路 我们可以考虑存储数组中连续indexDiff个数字&#xff0c;这样我们只需要在这连续的indexDiff个数字中查找相差小于等于valueDiff的两个数字的问题 对于该查找问题&#xff0c;我们可以考虑使用以valueDiff大小为一个桶&a…

自动化测试常用函数

目录 一、元素的定位 1、cssSelector 2、xpath &#xff08;1&#xff09;xpath 语法 1、获取HTML页面所有的节点 2、获取HTML页面指定的节点 3、获取一个节点中的直接子节点 4、获取一个节点的父节点 5、实现节点属性的匹配 6、使用指定索引的方式获取对应的节点内容…

MYSQL面试知识点手册

第一部分&#xff1a;MySQL 基础知识 1.1 MySQL 简介 MySQL 是世界上最流行的开源关系型数据库管理系统之一&#xff0c;它以性能卓越、稳定可靠和易用性而闻名。MySQL 主要应用在 Web 开发、大型互联网公司、企业级应用等场景&#xff0c;且广泛用于构建高并发、高可用的数据…

动态线程池(四)

动态线程池 dtp生命周期管理 生命周期相关类图 DtpExecutor EagerEtpExecutor OrderedDtpExecutor TaskWrapper任务包装器 MdcRunnable TaskWrappers NotifyEnum NoticeManager通知管理器 InvokerChain调用链

AI与量化投资人才培养计划-连接职场 助力走在金融行业前沿

AI与量化投资人才培养计划-连接职场 助力走在金融行业前沿 人工智能&#xff08;AI&#xff09;的快速发展&#xff0c;量化投资已逐渐成为金融行业的新趋势&#xff0c;对专业人才的需求日益迫切。本文将深入探讨一项针对AI与量化投资的人才培养计划&#xff0c;旨在为金融专业…

No operations allowed after statement closed

错误信息&#xff1a; The last packet successfully received from the server was 3,576,246 milliseconds ago. The last packet sent successfully to the server was 3,576,247 milliseconds ago. 参考解决方案 https://github.com/alibaba/druid/issues/5549 如果修改…