【C++笔记】容器适配器及deque和仿函数

【C++笔记】容器适配器及deque和仿函数

🔥个人主页大白的编程日记

🔥专栏C++笔记


文章目录

  • 【C++笔记】容器适配器及deque和仿函数
    • 前言
    • 一.容器适配器
      • 1.1什么是容器适配器
      • 1.2 STL标准库中stack和queue的底层结构
    • 二.stack
      • 2.1stack类模版
      • 2.2头文件问题
    • 三.queue
      • 3.1queue类模版
      • 3.2按需实例化
    • 四priority_queue
      • 4.1priority_queue的定义
      • 4.2仿函数
    • 五.deque
      • 5.1deque的定义
      • 5.2deque的结构
    • 后言

前言

哈喽,各位小伙伴大家好!上期我们讲了list结构剖析及其模拟实现。今天我们来讲一下dequeue和模版进阶。话不多说,我们进入正题!向大厂冲锋
在这里插入图片描述

一.容器适配器

1.1什么是容器适配器

适配器是一种设计模式(设计模式是一套被反复使用的、多数人知晓的、经过分类编目的、代码设计经验的总结),该种模式是将一个类的接口转换成客户希望的另外一个接口。


容器适配器就像我们的电流适配器一样。

容器适配器就是一种转化接口,把一种接口转化为我们需要的接口。

1.2 STL标准库中stack和queue的底层结构

虽然stack和queue中也可以存放元素,但在STL中并没有将其划分在容器的行列,而是将其称为容器适配器,这是因为stack和队列只是对其他容器的接口进行了包装,STL中stack和queue默认使用deque,比如:
如果我们需要写一个栈的类模版。我们会自己手搓一个出来。

template<class T>
class stack
{
private:T* ptr;size_t size;size_t capacity;
};

但是栈只需要栈顶插入和删除,也就是说只需要支持一端插入和删除即可。那我们的vector和list容器都支持一端插入和删除。所以我们可以用vector和list容器封装实现。

所以我们的栈就可以用一个容器封装实现

    //container适配转化出Stacktemplate<class T, class container = vector<T>>class Stack{public:private:container con;};

这里我们container传vector就是用vector适配转化的栈,传list就是list适配转化的栈。这就是我们通过container模版参数用容器适配器模式写的一个栈。

库里的栈也是这样做的。

在这里插入图片描述

二.stack

2.1stack类模版

这里我们用容器适配器写了一个栈的类模版。
成员是container。成员函数再调用容器的接口即可实现一个先进先出的栈。
默认使用vector容器适配。

//container适配转化出Stack
template<class T, class container = vector<T>>
class Stack
{
public:void push(T x){con.push_back(x);}void pop(){con.pop_back();}const T& Top() const{return con.back();}size_t size() const{return con.size();}bool empty() const{return con.empty();}
private:container con;
};

2.2头文件问题

我们自己写的文件包含在.cpp文件时尽量放在最后面。防止出现以下错误。

三.queue

3.1queue类模版

这里queue我们也是使用适配器模式。因为queue要求一端进一端出。
所以使用list容器适配更合适。也是调用对应容器的接口即可。

	//container适配转化出Queuetemplate<class T, class container =list<T>>class Queue{public:void push(T x){con.push_back(x);}void pop(){con.pop_front();}const T& front() const{return con.front();}const T& back() const{return con.back();}size_t size() const{return con.size();}bool empty() const{return con.empty();}private:container con;};

3.2按需实例化

类模版实例化是按需实例化。什么是按需实例化呢?

所以这里我们没报错,因为我们没有调用pop_front.

但当我们调用pop时就会报错。这就是因为按需实例化。

四priority_queue

4.1priority_queue的定义

priority_queue也是一个容器适配器.priority_queue也叫优先级队列
在这里插入图片描述

通过对priority_queue的底层结构就是堆,因此此处只需对对进行通用的封装即可。
堆我们用下标计算父子关系。所以priority_queue的默认容器是vector.

这里我们直接用容器封装即可。

template<class T, class container = vector<T>,class Compare =Less<T>>
class priority_queue
{
public:void AdjustDown( int parent){Compare com;int child = parent * 2 + 1;//孩子节点while (child < con.size()){int tmp = child;//左右孩子中最小的孩子if (tmp + 1 < con.size() && com(con[tmp], con[tmp + 1]))//防止没有右孩子{tmp = child + 1;}//假设法if (com(con[parent], con[tmp]))//判断{swap(con[parent], con[tmp]);//交换parent = tmp;child = parent * 2 + 1;}else{break;//调整完毕}}}void AdjustUp(int size){Compare com;int child = size - 1;//最后的节点while (child > 0){int parent = (child - 1) / 2;//父亲节点if (com(con[parent],con[child]))//判断{swap(con[child], con[parent]);//交换child = parent;}else{break;//调整完成}}}void push(const T& x){con.push_back(x);AdjustUp(con.size());}void pop(){swap(con[0], con[con.size() - 1]);con.pop_back();AdjustDown(0);}const T& top(){return con[0];}size_t size() const{return con.size();}bool empty() const{return con.empty();}
private:container con;
};

4.2仿函数

那我们怎么调整大堆小堆呢?
那就需要用到仿函数。
仿函数是个类。

template<class T>
struct Less
{int operator()(const T& x, const T& y){return x < y;}
};

仿函数这个类主要重载operator()。
这个()里面传两个对象的比较。

Compare com;
if (com(con[parent],con[child]))//判断

这里看起来很像函数调用,但是实际上是operator()的调用。
所以被叫做仿函数。仿函数我们想支持各种类型的比较就可以写成类模版。

template<class T, class container = vector<T>,class Compare =Less<T>>

所以我们在priority_queue的模版参数里传一个仿函数类型就可以控制大堆小堆。

通过传不同仿函数类型,我们就能控制不同的比较逻辑
从而控制大小堆。

五.deque

5.1deque的定义

我们可以发现库的的stack和queue没有用list和vector。
而是用了一个dequeue的容器。

那deque是什么呢?

deque是vector和list的缝合怪。

deque(双端队列):是一种双开口的"连续"空间的数据结构,双开口的含义是:可以在头尾两端进行插入和删除操作,且时间复杂度为O(1),与vector比较,头插效率高,不需要搬移元素;与list比较,空间利用率比较高。

5.2deque的结构

deque并不是真正连续的空间,而是由一段段连续的小空间拼接而成的,实际deque类似于一个动态的二维数组,其底层结构如下图所示:

deque是通过一个指针数组来控制数据存储的数组。

  • 下标

  • 迭代器
    deque 迭代器结构有四个指针

】

deque借助两个迭代器维护,start就是第一个数据的迭代器,finish就是最后一个数据的迭代器。
在这里插入图片描述

  • 迭代器遍历

    可以看到库里的实现和我们的差不多

  • 头插尾插

  • 中间插入删除
    deque中间插入删除也需要挪动数据。

  • operator[]
    因为头插时第一个数组可能不满所以先用cur-first+n计算位置。
    如果小于当前数组直接+n接口。
    否则就用N去计算位置。

- 总结

后言

这就是容器适配器及deque和仿函数。大家自己好好消化。今天就分享到这!感谢各位的耐心垂阅!咱们下期见!拜拜~

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

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

相关文章

centos7.X zabbix监控参数以及邮件报警和钉钉报警

1&#xff1a;zabbix安装 1.1 zabbix 环境要求 硬件配置: 2个CPU核心, 4G 内存, 50G 硬盘&#xff08;最低&#xff09; 操作系统: Linux centos7.2 x86_64 Python 2.7.x Mariadb Server ≥ 5.5.56 httpd-2.4.6-93.el7.centos.x86_64 PHP 5.4.161.2 zabbix安装版本 [rootnod…

基于向量检索的RAG大模型

一、什么是向量 向量是一种有大小和方向的数学对象。它可以表示为从一个点到另一个点的有向线段。例如&#xff0c;二维空间中的向量可以表示为 (&#x1d465;,&#x1d466;) &#xff0c;表示从原点 (0,0)到点 (&#x1d465;,&#x1d466;)的有向线段。 1.1、文本向量 1…

串口屏控制的自动滑轨(未完工)

序言 疫情期间自己制作了一个自动滑轨&#xff0c;基于无线遥控的&#xff0c;但是整体太大了&#xff0c;非常不方便携带&#xff0c;所以重新设计了一个新的&#xff0c;以2020铝型材做导轨的滑轨&#xff0c;目前2020做滑轨已经很成熟了&#xff0c;配件也都非常便宜&#x…

如何使用Get进行状态管理

文章目录 1. 概念介绍2. 思路与方法2.1 实现思路2.2 相关组件3. 示例代码4. 内容总结我们在上一章回中介绍了"使用get进行依赖管理"相关的内容,本章回中将介绍如何使用get进行状态管理一.闲话休提,让我们一起Talk Flutter吧。 1. 概念介绍 在Flutter开发中状态管理…

计算机视觉常用数据集Cityscapes的介绍、下载、转为YOLO格式进行训练

我在寻找Cityscapes数据集的时候花了一番功夫&#xff0c;因为官网下载需要用公司或学校邮箱邮箱注册账号&#xff0c;等待审核通过后才能进行下载数据集。并且一开始我也并不了解Cityscapes的格式和内容是什么样的&#xff0c;现在我弄明白后写下这篇文章&#xff0c;用于记录…

033_Structure_Static_In_Matlab求解结构静力学问题两套方法

结构静力学问题 静力学问现在是已经很简单的问题&#xff0c;在材料各向同性的情况下&#xff0c;对于弹性固体材料&#xff0c;很容易通过有限元求解。特别是线弹性问题&#xff0c;方程的矩阵形式可以很容易的写出&#xff08;准确得说是很容易通过有限元表达&#xff09;&a…

rnn/lstm 项目实战

tip:本项目用到的数据和代码在https://pan.baidu.com/s/1Cw6OSSWJevSv7T1ouk4B6Q?pwdz6w2 1. RNN : 预测股价 任务&#xff1a;基于zgpa_train.csv数据,建立RNN模型,预测股价 1.完成数据预处理&#xff0c;将序列数据转化为可用于RNN输入的数据 2.对新数据zgpa_test.csv进…

jenkins 构建报错 mvn: command not found

首先安装过 maven&#xff0c;并且配置过环境变量 win r ,输入 cmd 键入 mvn -v 出现上图输出&#xff0c;则证明安装成功。 原因 jenkins 没有 maven 配置全局属性, 导致无法找到 mvn 命令。 解决方案 找到全局属性&#xff0c;点击新增&#xff0c;配置 MAVEN_HOME 路…

轮廓图【HTML+CSS+JavaScript】

给大家分享一个很好看的轮播图&#xff0c;这个也是之前看到别人写的效果感觉很好看&#xff0c;所以后面也自己实现了一下&#xff0c;在这里分享给大家&#xff0c;希望大家也可以有所收获 轮播图效果&#xff1a; 视频效果有点浑浊&#xff0c;大家凑合着看&#xff0c;大家…

ChatGPT变AI搜索引擎!以后还需要谷歌吗?

前言 在北京时间11月1日凌晨&#xff0c;正值ChatGPT两岁生日之际&#xff0c;OpenAI宣布推出最新的人工智能搜索体验&#xff01;具备实时网络功能&#xff01;与 Google 展开直接竞争。 ChatGPT搜索的推出标志着ChatGPT成功消除了即时信息这一最后的短板。 这项新功能可供 …

Netty 组件介绍 - ByteBuf

直接内存&堆内存 ByteBuf buffer ByteBufAllocator.DEFAULT.heapBuffer(10);ByteBuf byteBuf ByteBufAllocator.DEFAULT.directBuffer(10); 组成 ByteBuf维护了两个不同的索引&#xff0c;一个用于读取&#xff0c;一个用于写入。 写入 内存回收 堆内存使用的是JVM内…

都快2025年了,来看看哪个编程语言才是时下热门吧

早上好啊&#xff0c;大佬们&#xff0c;今天咱们不讲知识&#xff0c;今天我们来看看时下热门的编程语言都是哪些&#xff0c;大佬们又都是在学哪些语言呢。 最近一些朋友和我在讨论哪个编程语言是现在 最好用 最厉害 的编程语言。 有人说&#xff0c;Python简单好用&#xf…

【雷达信号数据集】雷达脉冲活动分段的多级学习算法【附下载链接】

摘要 无线电信号识别是电子战中的一项重要功能。电子战系统需要精确识别和定位雷达脉冲活动&#xff0c;以产生有效的对抗措施。尽管这些任务很重要&#xff0c;但基于深度学习的雷达脉冲活动识别方法在很大程度上仍未得到充分探索。虽然之前已经探索了用于雷达调制识别的深度…

vscode php Launch built-in server and debug, PHP内置服务xdebug调试,自定义启动参数配置使用示例

在vscode中&#xff0c;当我们安装了插件 PHP Debug&#xff08;xdebug.php-debug&#xff09;或者 xdebug.php-pack 后 我们通过内置默认的 php xdebug配置启动php项目后&#xff0c;默认情况下我们在vscode中设置断点是不会生效的&#xff0c;因为我们的内置php服务默认启动时…

(二 上)VB 2010 设计初步

目录 一、常用类应用 1.Console类控制台 2.窗体基本控件 二、面向对象程序设计 1.类和对象 2.对象的属性、方法、事件属 1.属性 2.方法 3.事件、事件过程 1.事件 2.事件过程 3.对象浏览器 三、.NET类库与命名空间 1.命名空间 常用命名空间 1.System命名空间 2.…

[CARLA系列--01]CARLA 0.9.15 在Windows下的安装教程(一)

Carla是一款开源的自动驾驶仿真器&#xff0c;它基本可以用来帮助训练自动驾驶的所有模块&#xff0c;包括感知系统&#xff0c;Localization, 规划系统等等.Carla这个产品目前已经更新到了最新的0.9.15版本,目前遇到好多人在windows系统上如何安装可编辑版的Carla遇到了好多问…

禾川HCQ1控制器程序编译报错如何解决

1、第一次打开用户程序 2、提示库未安装 3、安装库文件 4、脉冲轴库未安装 5、没有错误 去禾川自动化官网,把可以安装的包和库都安装下,程序编译就没有错误了。 6、下载相关包文件

ubuntu20安装opencv3.2记录

系统环境 ubuntu20安装了ros-noetic&#xff0c;所以系统默认装了opencv4.2.0&#xff0c;但是跑fastlivo推荐的是opencv3.2.0&#xff0c;而且海康相机别人写的ros驱动&#xff08;海康相机ros驱动&#xff09;也是需要opencv3.2.0&#xff0c;最终还是选择安装多版本的openc…

基于NVIDIA NIM平台实现盲人过马路的demo(一)

前言:利用NVIDIA NIM平台提供的大模型进行编辑,通过llama-3.2-90b-vision-instruct模型进行初步的图片检测 step1: 部署大模型到本地,引用所需要的库 import os import requests import base64 import cv2 import time from datetime import datetimestep2: 观看官方使用文…

MATLAB下的四个模型的IMM例程(CV、CT左转、CT右转、CA四个模型),附源代码可复制

文章目录 基于IMM算法的目标跟踪概述源代码运行结果代码结构与功能1. 初始化2. 仿真参数设置3. 模型参数设置4. 生成量测数据5. IMM算法初始化6. IMM迭代7. 绘图8. 辅助函数总结基于IMM算法的目标跟踪 概述 该MATLAB代码实现了基于交互式多模型(IMM)算法的目标跟踪,旨在估…