STL:双端队列容器适配器仿函数优先级队列

news2025/1/10 18:38:34

deque

  • 双端队列可以在头部和尾部进行插入删除操作
  • 与vector相比,头插效率高,不需要搬移元素
    与list相比,空间利用率高

deque逻辑上空间是连续的,物理上并不是,是由一段段小空间拼接而成的

双端队列的迭代器比较复杂

  • cur:指向空间中被遍历的那个元素
  • first:指向空间开始
  • last:指向空间末尾
  • node:指向map中保存该段空间的地址
    当cur走到first或者last位置,说明已经将该空间中的元素遍历结束,需要找下一块空间(node++或者–)

在这里插入图片描述

容器适配器

C语言中,栈封装数组,队列封装链表,
C++中,栈和队列使用deque实现
原因:vector中的扩容成本高,list中有大量节点,造成很多内存碎片

容器适配器是将一个接口转换成另外一种接口,这样解释确实过于简单,

  • 先要知道,deque中定义了许多的接口如头插头删,尾插尾删,判空等操作,
  • 这些操作不管是栈中特性函数,还是队列中的特性函数,deque中都有
  • 若实现stack,stl把deque作为stack的底层,抽出deque中的部分方法,
  • 比如尾插尾删,判空,返回队尾元素,进行包装从而实现栈;尾插尾删函数变成出栈入栈函数,返回队尾元素函数变成返回栈顶元素函数

迭代器适配器:list反向迭代器的实现,封装了正向迭代器(抽出正向迭代器中的方法重新进行封装)

仿函数

仿函数又称函数对象(可以像函数一样调用的对象称为函数对象)
实现:在类中将函数调用运算符() 重载,该类的对象就可以像函数一样使用

在这里插入图片描述
重载()后,通过less类定义的对象,去调用成员函数

优先级队列(仿函数与容器适配器的应用)

封装vector实现

  • 优先级队列本质是堆
  • 堆是完全二叉树+条件(父节点比孩子节点大或者小)
    完全二叉树适合用数组存储
    所以优先级队列的底层是用vector来存储元素

在这里插入图片描述

适配器详述

  • 103行,vector是一个类模板,用int将该模板实例化,所以vector< int >是一个实际类型,将这个类型名用container代替,并用新类型名定义一个变量
  • 优先级队列的pop函数是使用vector中的pop作为核心逻辑,并添加新逻辑而实现的
  • 添加新的函数,向上调整和向下调整函数
  • 组成了新容器的接口,把这种容器称为容器适配器

所以stack和queue严格说并不是容器,而是容器适配器

仿函数详述

仿函数又称函数对象(可以像函数一样调用的对象称为函数对象)
实现:在类中将函数调用运算符重载,该类的对象就可以像函数一样使用
函数调用运算符就是 ( )

通俗来说就是把函数封装到类里面,要使用该函数时,只需要定义一个这个类的对象,通过对象调用运算符重载函数,使用该功能

代码84~100行是实现两个不同比较方式的仿函数,同容器适配器一样,在类模板参数列表中重命名,112行定义类对象,117行是对象调用()运算符重载函数,将括号中的两个参数传给类中的成员函数

sort中仿函数的应用

sort是一个函数模板

  • sort的三个参数,前两个参数是待排序的区间,第三个参数是排序方式
  • 而sort是一个函数,参数是普通变量
  • 仿函数是一个类型,第三个参数不能传类型,
    所以仿函数要想作为sort函数的参数,需要这样写
  • 后面加()表面这个类产生了一个匿名对象

在这里插入图片描述

而arr是指针变量,迭代器的本质又是指针,所以可以推出arr就是一个迭代器对象

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

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

相关文章

Python爬虫技术及其原理详解

概要 随着互联网的发展&#xff0c;大量的数据被存储在网络上&#xff0c;而我们需要从中获取有用的信息。Python作为一种功能强大且易于学习的编程语言&#xff0c;被广泛用于网络爬虫的开发。本文将详细介绍Python爬虫所需的技术及其原理&#xff0c;并提供相关的代码案例。 …

Python—数据结构(一)

先放一张自己学习和整理归纳的思维导图&#xff0c;以便让大家都知道我自己的整体学习路线。 数据结构的学习路上内容枯燥&#xff0c;但坚持下来一定有很大的收获&#xff01;加油&#x1f4aa;&#x1f3fb;&#xff01; 数据结构 数据的概念数据元素&#xff1a; 若干基本…

php基于redis处理session的方法

php基于redis处理session的方法 一个基于redis的处理session的方法&#xff0c;如下&#xff1a; class Session_custom { private $redis; // redis实例 private $prefix sess_; // session_id前缀 // 会话开始时&#xff0c;会执行该方法&#xff0c;连接redis服务器 p…

【JVM】JVM执行流程 JVM类加载 垃圾回收机制等

目录 &#x1f337;1、JVM是什么&#xff1f; &#x1f337;2、JVM的执行流程&#xff08;能够描述数据区5部分&#xff09; &#x1f337;3、JVM类加载过程 &#x1f337;4、双亲委派机制&#xff1a;描述类加载的过程 问题1&#xff1a;类加载器 问题2&#xff1a;什么…

前端知识点视频补充

使用工具&#xff1a; Vscode使用&#xff1a; 需要下载插件&#xff1a;open in browser。这个插件可以快速打开浏览器。 选择文件夹有两种方式&#xff1a;选择打开文件、拖拽方式&#xff08;这种最方便&#xff09; 快捷键&#xff1a;快速生成Htm结构文件&#xff1a;…

msvcr100.dll丢失的解决方法

在解决msvcr100.dll丢失问题前&#xff0c;给大家介绍一下为什么msvcr100.dll会丢失 msvcr100.dll文件丢失的原因可能有多种。以下是一些常见的原因&#xff1a; 文件被误删&#xff1a;有时候&#xff0c;用户可能会误删除msvcr100.dll文件&#xff0c;导致其丢失。 文件损…

蓝桥杯专题-真题版含答案-【生命之树】【消除尾一】【密码脱落】【生日蜡烛】

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例点击跳转>软考全系列点击跳转>蓝桥系列 &#x1f449;关于作者 专注于Android/Unity和各种游…

用户管理功能

后端 # 获取用户列表 bp.get("/user/list") def user_list():users UserModel.query.order_by(UserModel.join_time.desc()).all()user_list [user.to_dict() for user in users]return restful.ok(datauser_list)# 用户是否可用 bp.post("/user/active"…

json-server提供json接口服务--示例版本

一、基于以下数据做接口常用功能的查询 1.1启动服务并且创建数据库文件&#xff0c;对外提供文件如下&#xff1a; {"posts": [{"author": "杰瑞","id": 1},{"id": 2,"title": "json-server","au…

通过Jmeter压测存储过程

一、存储过程准备&#xff1a; 1、建立一个空表&#xff1a; 1 CREATE TABLE test_data ( id NUMBER, name VARCHAR2(50), age NUMBER ); 2、建立一个存储过程&#xff1a; 1 2 3 4 5 6 7 8 9 CREATE OR REPLACE PROCEDURE insert_test_data (n IN NUMBER) AS BEGIN --E…

顺丰基于 Flink CDC + Hudi 推进实时业务落地

摘要&#xff1a;本文整理自大数据研发高级工程师唐尚文&#xff0c;在 Flink Forward Asia 2022 数据集成专场的分享。本篇内容主要分为三个部分&#xff1a; 应用场景 实践与优化 未来规划 点击查看原文视频 & 演讲PPT 一、应用场景 1.1 顺丰集团业务概览 顺丰除了大家…

LeetCode153.Find-Minimum-In-Rotated-Sorted-Array<寻找旋转排序数组中的最小值>

题目&#xff1a; 寻找旋转排序数组中的最小值 思路&#xff1a; (1) sort 排序 (2) 循环找最小数。 代码是&#xff1a; //code//1 class Solution { public:int findMin(vector<int>& nums) {int len nums.size() - 1;sort(nums.begin(),nums.end());int fir…

go学习 模块与包 - Init函数 - 如何导入第三方包 - 切片与数组的数据传递方式 - go中文件的读写

目录 包&#xff08;package&#xff09;是组织和复用代码的基本单元。 包的种类&#xff1a; 包的导入 包的组成 如下两个文件中定义了A变量和 sc_num变量&#xff0c;他们的首字母开头分别为大写和小写&#xff0c;因此可以说明A变量是公有变量&#xff0c;而sc_num是私…

【unity之IMGUI实践】通用API实现抽象行为封装【五】

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;uni…

【数字图像处理与应用】模板匹配

【数字图像处理与应用】模板匹配 题目模板匹配原理Matlab代码实现算法介绍显示图像的匹配结果 (最匹配的一个)MATLAB实现运行结果图像的相关值结果&#xff1a;在原图像上绘制检测到的目标位置&#xff1a;显示检测到的目标坐标&#xff1a; 显示图像的匹配结果 (最匹配的三个&…

计讯物联5G千兆网关TG463赋能无人船应用方案,开启自动巡检的智能模式

方案背景 水电站、水库、堤坝等水利工程水下构筑物常年处于水下&#xff0c;并在复杂的水流环境下运行&#xff0c;难免会出现磨蚀、露筋等损伤&#xff0c;而传统的安全监测方式一般是通过潜水员检查上层水柱或通过降低水位进行人工巡查&#xff0c;不仅成本高&#xff0c;效…

深入理解Linux网络——TCP协议三次握手和四次挥手详细流程

文章目录 一、三次握手流程二、为什么握手是三次三、关闭连接的情况四、四次挥手流程五、为什么挥手是四次 系列文章&#xff1a; 深入理解Linux网络——内核是如何接收到网络包的深入理解Linux网络——内核与用户进程协作之同步阻塞方案&#xff08;BIO&#xff09;深入理解L…

EGE-UNet, 轻量化U-Net

随着transform 的出现&#xff0c;现在语义分割网路结构越来越复杂&#xff0c;轻量化网路也较少了&#xff0c;有些轻量化也只是名义上的轻量化。今天我看到一篇很好的论文&#xff0c;上海交大发表在 MICCAI 2023 的最新研究工作&#xff0c;一个称为Efficient Group Enhance…

堆排序与直接选择排序

目录 一、直接选择排序 1.基本思想 2.直接选择排序的特性总结 3.代码实现&#xff1a; 二、堆排序 1. 概念&#xff1a; 2.图像实现&#xff1a; 3.代码实现&#xff1a; 一、直接选择排序 1.基本思想 每一次从待排序的数据元素中选出最小&#xff08;或最大&#xff09…

Edge 中比较独特的调试技巧

背景 大家日常开发基本都会使用 Chrome&#xff0c;毕竟确实好用。但是基于 Chromium 的新版 Microsoft Edge 已于 2020 年 1 月 15 日发布。 Edge 目前的使用基本跟 Chrome 差不多了&#xff0c;但显然&#xff0c;Edge 团队不仅仅想当 Chrome 的备用。他们也提供了一些特有…