【C++】stackqueue
适配器是一种设计模式 , 该种模式是将一个类的接口转换成客户希望的另外一个接口 。虽然 stack 和 queue 中也可以存放元素,但在 STL 中并没有将其划分在容器的行列,而是将其称为 容器适配 器 ,这是因为 stack 和队列只是对其他容器的接口进行了包装, STL 中 stack 和 queue 默认使用 deque
stack基本介绍
1. stack 是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行元素的插入与提取操作。2. stack 是作为容器适配器被实现的,容器适配器即是对特定类封装作为其底层的容器,并提供一组特定的成员函数来访问其元素,将特定类作为其底层的,元素特定容器的尾部( 即栈顶 ) 被压入和弹出。3. stack 的底层容器可以是任何标准的容器类模板或者一些其他特定的容器类,这些容器类应该支持以下操作:empty :判空操作back :获取尾部元素操作push_back :尾部插入元素操作pop_back :尾部删除元素操作4. 标准容器 vector 、 deque 、 list 均符合这些需求,默认情况下,如果没有为 stack 指定特定的底层容器,默认情况下使用deque 。
stack()构造空的栈empty()检测 stack 是否为空size()返回 stack 中元素的个数top()返回栈顶元素的引用push()将元素 val 压入 stack 中pop()将 stack 中尾部的元素弹出
stack模拟实现
queue基本介绍
1. 队列是一种容器适配器,专门用于在 FIFO 上下文 ( 先进先出 ) 中操作,其中从容器一端插入元素,另一端提取元素。2. 队列作为容器适配器实现,容器适配器即将特定容器类封装作为其底层容器类, queue 提供一组特定的成员函数来访问其元素。元素从队尾入队列,从队头出队列。3. 底层容器可以是标准容器类模板之一,也可以是其他专门设计的容器类。该底层容器应至少支持以下操作:empty :检测队列是否为空size :返回队列中有效元素的个数front :返回队头元素的引用back :返回队尾元素的引用push_back :在队列尾部入队列pop_front :在队列头部出队列4. 标准容器类 deque 和 list 满足了这些要求。默认情况下,如果没有为 queue 实例化指定容器类,则使用标准容器deque 。
queue()构造空的队列empty()检测队列是否为空,是返回 true ,否则返回 falsesize()返回队列中有效元素的个数front()返回队头元素的引用back()返回队尾元素的引用push()在队尾将元素 val 入队列pop()将队头元素出队列
queue模拟实现
stack和queue模板中都提到了deque,那么我们来了解一下deque
deque介绍
deque( 双端队列 ) :是一种双开口的 " 连续 " 空间的数据结构 ,双开口的含义是:可以在头尾两端进行插入和删除操作,且时间复杂度为O(1) ,与 vector 比较,头插效率高,不需要搬移元素;与 list 比较,空间利用率比较高我们可以先看一下它的接口:
仔细观察我们会发现,它的接口包含了vector和list对数据进行操作的接口,比如vector的[ ]按下标进行访问,链表的头插头删等,仿佛deque融合了vector和list的特点,是一个十分完美的容器。
但是这个容器存在它的缺陷,因此应用并不广泛,它的结构跟vector和list对比如下图:
通过对它的结构的分析,我们不难发现,deque非常适合头插头删,尾插尾删的操作,因此它十分适合用来适配栈和队列的默认适配器。
priority_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 来自动完成此操作。
priority_queue()/priority_queue(first, last)构造一个空的优先级队列empty( )检测优先级队列是否为空,是返回 true ,否则返回 falsetop( )返回优先级队列中最大 ( 最小元素 ) ,即堆顶元素push(x)在优先级队列中插入元素 xpop ()删除优先级队列中最大 ( 最小 ) 元素,即堆顶元素
priority_queue模拟实现
由于优先级队列实际上是一个堆,而且默认实现的是小堆,通过传递第三个模板参数,利用仿函数(重载())实现大小堆的转换。
相关文章:
【C++】stackqueue
适配器是一种设计模式 , 该种模式是将一个类的接口转换成客户希望的另外一个接口 。 虽然 stack 和 queue 中也可以存放元素,但在 STL 中并没有将其划分在容器的行列,而是将其称为 容器适配 器 ,这是因为 stack 和队列只是对其他容…...
Hive篇面试题+详解
Hive篇面试题 1.什么是Hive?它的主要功能是什么? Hive是一个基于Hadoop的数据仓库工具,它提供了一个类SQL的查询语言(HiveQL)来查询和分析存储在Hadoop集群中的大规模数据。Hive的主要功能是将结构化数据映射到Hadoop…...
Mysql批量插入更新如何拆分大事务?
拆分大事务 一、解决方案二、遇到问题之前在运行Mysql任务的时候报错:binlog(1610646347 bytes) write threshold exceeded,原因是Mysql任务提交的是个大事务,超出binlog设定阈值,使得系统自动终止事务 一、解决方案 使用limit分页拆分大事务 CREATE PROCEDURE `split_tran…...
【计算机网络原理】初始网络基础
文章目录 1. 网络发展史1.1 单机时代1.2 网络互连局域网 LAN广域网 WAN 2. 网络通信基础2.1 IP 地址2.2 端口号2.3 协议2.4 五元组2.5 协议分层2.5.1 OSI七层模型2.5.2 TCP/IP五层模型 2.6 封装和分用2.6.1 数据封装(发送方情况)2.6.2 数据分用(接收方情况) 总结 1. 网络发展史…...
【sqlserver】配置管理器打不开
问题描述 无法连接到 WMI 提供程序。您没有权限或者该服务器无法访问。请注意,您只能使用SQL Server 配置管理器来管理 SQL Server 2005 和更高版本的服务 器。无效类[0x80041010] 解决方式: 命令提示符-右键-以管理员身份运行,再把以下代码执行一遍&…...
磁盘清理 | 已经卸载的软件还出现在应用和功能里怎么办?
一句话总结解决方法: 安装Geek Uninstaller,删除卸载残留。 问题描述: 最近磁盘满了,需要删除一些平时不常用的软件,但是发现一个问题。就是已经删除的软件,仍然会出现在“应用与功能”中。并且显示卸载图标为灰色&am…...
C++之异常
目录 一、C语言传统的处理错误的方式 二、C的异常 1、概念 2、关键字 3、基本格式 三、异常的抛出和捕获 1、异常的抛出和匹配原则 2、 在函数调用链中异常栈展开匹配原则 四、异常抛派生类,基类捕获 五、异常的重新抛出 六、异常安全 七、异常的优缺点…...
动态天气预报:Living Weather HD for Mac
Living Weather HD能够为Mac用户提供及时、准确、个性化的天气信息,并提供了丰富的定制选项,使用户能够更加方便地查看天气状况。 具有以下特点: 显示世界各地的准确天气预报和当地时间。自动探测出用户所在的首个地点,并通过搜…...
深度神经网络时与协方差矩阵
平时训练深度神经网络时,什么时候用到了协方差矩阵 在深度神经网络的平时训练过程中,一般情况下不直接使用协方差矩阵。然而,协方差矩阵的概念和相关性的考虑在某些情况下可以对网络的训练和优化起到一定的指导作用。 下面是一些与协方差矩…...
idea中java类属性(字段)链式赋值
很多人看到标题可能会想到 lombok 的 Builder,lombok 在国内用的挺多的,开源的组件中 mybatis-plus 中用到了这个,使用这个有一个问题就是通过对应 get 和 set 方法找不到对应的赋值方法,因为 lombok 使用了 apt 在编译期生成了相…...
vue通知(滚动)
1. li宽度不顾定 <template><div id"app"><div id"box" mouseover"clearLeft" mouseleave"setLeft"><ul :style"{ transform: translateX( left px) }" ref"cmdlist"><li v-for&qu…...
linux安装新版本git2、配置github-ssh。(centos、aws)
一、安装Git 1、yum默认版本git #1.安装git sudo yum install git -y #2.确认Git已经安装成功 git --version如果要安装较新版本,可以安装一个repo ,但是我这第一次尝试失败了,执行完提示找不到git2u,ius repo也连不上。而且每次…...
毅速丨3D打印结合拓扑优化 让轻量化制造更容易
制造轻量化对于提高能源利用效率、提高产品性能和减少环境影响,推动制造业的绿色化、高质量发展具有重要的促进作用。 轻量化设计对许多领域都有着重要影响,尤其是那些需要降低能源消耗、提高运输效率或减少对环境影响的领域。如航空航天,轻量…...
6252: 【C1】【分支】比较大小(一)
目录 题目描述 输入 输出 样例输入 样例输出 提示 来源 C代码: 题目描述 输入两个整数,输出较大数(两数相等输出任意一个) 输入 两行 第一行一个整数:m 第二行一个整数:n ( -30000 < m , n…...
网工实验手册:RSTP如何配置?
1. 实验目的 熟悉RSTP的应用场景掌握RSTP的配置方法 想要华为数通配套实验拓扑和配置笔记的朋友们点赞关注,评论区留下邮箱发给你! 2. 实验拓扑 实验拓扑如图所示: 图:RSTP的配置 3. 实验步骤 (1) …...
uniapp开发h5引入第三方js(sdk)
manifest.json 应用配置 | uni-app官网 根据文档上描述需要自定义模板的场景为: 方法一: 起初以为是在原有的index.html基础上再新建一个html文件,在项目根目录建立一个template.h5.html(仿照hello-uni-app项目)&…...
Could not find artifact com.sleepycat;je:jar:7.3.7 in aliyunmaven
在编译inlong源码时报的错误,去本地库里发现只有lastupdate的文件,就又去maven库里看了一下Maven Repository: com.sleepycat je (mvnrepository.com),发现没有这个版本,将版本进行修改错误解决...
rust学习—— 控制流if 表达式
控制流 根据条件是否为真来决定是否执行某些代码,或根据条件是否为真来重复运行一段代码,是大部分编程语言的基本组成部分。Rust 代码中最常见的用来控制执行流的结构是 if 表达式和循环。 if 表达式 if 表达式允许根据条件执行不同的代码分支。你提供…...
POSIX信号量
目录 信号量的原理 信号量函数 使用信号量实现线程互斥功能 基于环形队列的生产消费模型 生产者和消费者必须遵守的两个规则 信号量的原理 通过之前的学习,我们知道有的资源可能会被多个执行流同时申请访问,我们将这种资源叫做临界资源,…...
stable diffusion和midjourney哪个好
midjourney和stable diffusion哪个好?midjourney和stable diffusion的区别?那么今天就从这2款软件入手,来探索一下他们的功能的各项区别吧,让你选择更适合你的一款ai软件。 截至目前,我们目睹了生成式人工智能工具的在…...
从荧光微球选购到成像避坑:一次完整的PSF测量实战记录(附ThermoFisher beads型号选择建议)
从荧光微球选购到成像避坑:一次完整的PSF测量实战记录 第一次独立完成PSF测量时,实验室的冷光灯下只有我和那瓶价值四位数的荧光微球面面相觑。作为课题组第一个尝试这项技术的人,我翻遍了文献却找不到关于"如何根据显微镜参数选择beads…...
解放双手的航海之旅:碧蓝航线Alas自动化助手深度探索
解放双手的航海之旅:碧蓝航线Alas自动化助手深度探索 【免费下载链接】AzurLaneAutoScript Azur Lane bot (CN/EN/JP/TW) 碧蓝航线脚本 | 无缝委托科研,全自动大世界 项目地址: https://gitcode.com/gh_mirrors/az/AzurLaneAutoScript 你是否曾因…...
工具应用—Doxygen文档工具的应用
一、文档工具和Doxygen 在实际的开发中,写文档是最让开发者抵触的。对于大多数的开发者来说,写代码比写文档要感觉爽很多。但在实际的开发过程中,文档又是必不可少的。且不说给协作者提供相关的接口文档,公司但凡正规一些要过一些…...
5分钟掌握Windows和Office一键激活:KMS_VL_ALL_AIO智能激活工具终极指南
5分钟掌握Windows和Office一键激活:KMS_VL_ALL_AIO智能激活工具终极指南 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为Windows系统频繁弹出激活提示而烦恼吗?Off…...
告别硬编码!用Qt Linguist和qsTr优雅管理你的Qml应用多语言文案
工程化多语言管理:用Qt Linguist构建可维护的Qml应用 当你的Qml应用从demo阶段走向产品化时,那些散落在各个文件中的文本字符串会逐渐成为维护的噩梦。想象一下这样的场景:产品经理突然要求为法语用户添加支持,而你需要在几十个Qm…...
real-anime-z开源可部署优势:离线环境稳定运行保障项目交付周期
real-anime-z开源可部署优势:离线环境稳定运行保障项目交付周期 1. 项目概述 real-anime-z是一款基于Z-Image基础镜像构建的LoRA模型,专注于生成高质量的真实动画风格图片。该项目采用Xinference框架进行模型服务部署,并通过Gradio提供用户…...
Leather Dress Collection效果展示:12款LoRA在肤色适配、光影反射、皮革光泽一致性表现
Leather Dress Collection效果展示:12款LoRA在肤色适配、光影反射、皮革光泽一致性表现 1. 项目概述 Leather Dress Collection 是一个基于Stable Diffusion 1.5的LoRA模型集合,专注于生成各种皮革服装风格的图像。这套模型由Stable Yogi开发ÿ…...
为什么要学习AI大模型?掌握AI大模型:抢占未来职场制高点,成为高薪抢手人才!
本文阐述了企业对AI大模型需求的增长及其带来的商业价值,如降本增效、产品创新等。同时,文章强调了学习AI大模型对个人职业发展的益处,包括薪资提升、效率提高、拓宽职业道路等。文章还展望了AI大模型广阔的职业前景,并提供学习资…...
Git版本控制工具(Linux运维CICD版)
git概述 Git诞生:分布式项目管理工具,目前整个行业内最流行最受欢迎的项目版本管理工具 开发者:Linus Torvalds Linux的创始人 Linux诞生以后,全球很多开发者开发了很多个版本的Linux,提交给Linus Torvalds Linus To…...
OpenWrt单GPIO模拟SDI-12总线:从协议解析到驱动实现
1. SDI-12协议基础解析 SDI-12(Serial Digital Interface)是一种专门为智能传感器设计的串行通信协议。我第一次接触这个协议是在一个农业物联网项目中,当时需要连接土壤温湿度传感器。这个协议最大的特点就是只需要三根线(数据线…...




