map的使用(c++)

1.map类的声明

template < class Key,
           class T,
           class Compare = less<Key>, 
           class Alloc = allocator<pair<const Key,T>>> class map;

2.pari类型介绍

map底层的红黑树节点中的数据,使⽤pair<Key,T>存储键值对数据。就是对,key和value进行了多一层的封装。

typedef pair<const Key, T> value_type;
template <class T1, class T2>
struct pair
{

   typedef T1 first_type;
   typedef T2 second_type;
   T1 first;
   T2 second;
   pair(): first(T1()), second(T2())
       {}
   pair(const T1& a, const T2& b): first(a), second(b)
       {}
   template<class U, class V>
   pair (const pair<U,V>& pr): first(pr.first), second(pr.second)
       {}
};
template <class T1,class T2>
inline pair<T1,T2> make_pair (T1 x, T2 y)
{
    return ( pair<T1,T2>(x,y) );
}

3.map的构造

无参默认构造:

explicit map (const key_compare& comp = key_compare(),
              const allocator_type& alloc = allocator_type());

迭代区间构造:

template <class InputIterator>
map (InputIterator first, InputIterator last,
     const key_compare& comp = key_compare(),
     const allocator_type& = allocator_type());

拷贝构造:

map (const map& x);

列表构造:

map (initializer_list<value_type> il,
     const key_compare& comp = key_compare(),
     const allocator_type& alloc = allocator_type());

正向迭代器:

iterator begin();
iterator end();

反向迭代器:

reverse_iterator rbegin();
reverse_iterator rend();

4.map的增删查

map增接口,插入的pair键值对数据,跟set不同,但是查和删的接口只用关键字key跟set是完全类似的,不过find返回的是iterator,不仅仅可以确认key在不在,还找到key映射的value,同时通过迭代还可以修改value。

单个数据插入:

如果已经key存在则插入失败,key存在相等value不相等也会插入失败

pair<iterator,bool> insert (const value_type& val);

列表插入:

已经在容器中存在的值不会插入

void insert (initializer_list<value_type> il);

eg:

map<string, string> dict = { {"left", "左边"}, {"right", "右边"},
                           {"insert", "插⼊"},{ "string", "字符串" } };

迭代器区间插入:

已经在容器中存在的值不会插入

template <class InputIterator>
void insert (InputIterator first, InputIterator last);

查找k:

返回k所在的迭代器,没有找到返回end()

iterator find (const key_type& k);

查找k:

返回k的个数

size_type count (const key_type& k) const;

删除⼀个迭代器位置的值:
 

iterator erase (const_iterator position);

删除k:

k存在返回0,存在返回1

size_type erase (const key_type& k);

删除⼀段迭代器区间的值:

iterator erase (const_iterator first, const_iterator last);

返回大于等于val的迭代器:

iterator lower_bound (const key_type& k);

返回大于val的迭代器:

const_iterator lower_bound (const key_type& k) const;

5.map的数据修改

set不支持修改,但是map支持修改value。

map第⼀个支持修改的式式时通过迭代器,迭代器遍历时或者find返回key所在的iterator修改,map还有⼀个非常重要的修改接口operator[],但是operator[]不仅支持修改,还支持插入数据和查找数据

insert插入⼀个pair<key, T>对象
    1、如果key已经在map中,插⼊失败,则返回⼀个pair<iterator,bool>对象,返回pair对象
first是key所在结点的迭代器,second是false
    2、如果key不在在map中,插⼊成功,则返回⼀个pair<iterator,bool>对象,返回pair对象
first是新插⼊key所在结点的迭代器,second是true
    无论插入成功还是失败,返回pair<iterator,bool>对象的first都会指向key所在的迭代器
    也就意味着insert插入失败时充当了查找的功能,因为这点,insert可以用来实现
operator[]
注意:这里有两个pair,⼀个是map底层红黑树节点中存的pair<key, T>,另⼀个是insert返回值pair<iterator,bool>

operator[]的实现:

mapped_type& operator[] (const key_type& k)
{
   pair<iterator, bool> ret = insert({ k, mapped_type() });
   iterator it = ret.first;
   return it->second;
}

6.map和multimap的差异

multimap和map的使用基本完全类似,主要区别点在于multimap支持关键值key冗余,并且multimap不支持[]。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

大龄离异单身女性网上找陪伴搭子一起搭伙过生活的自救经历分享

在繁忙的都市生活中&#xff0c;李梅是一个独立自主的大龄离异女性。经历了婚姻的失败后&#xff0c;她更加珍惜自己的生活空间与时间&#xff0c;同时也渴望能够找到一个可以相互扶持、共度余生的伴侣。网络成为了她的新尝试领域&#xff0c;在这里&#xff0c;她希望能够遇到…

php语法学习

启动php 进入软件 打开文件&#xff1a;编写代码 $php true; $java false; var_dump($php);//输出变量细节 var_dump($java) 字符串 注意可以使用双引号也可以使用单引号 测试 $php "最好学web语言"; $java 脱胎于c语言; var_dump($php);//输出变量细节 var…

spark统一内存模型 详解

Apache Spark 是一个用于大规模数据处理的分布式计算框架&#xff0c;它支持多种处理模型&#xff08;如批处理、流处理、SQL、机器学习等&#xff09;。为了高效地在分布式环境中处理这些多样化的工作负载&#xff0c;Spark 在 2.x 版本后引入了统一内存管理模型&#xff0c;以…

配置适合Gurobi的机器硬件环境需要考虑的因素

在使用 Gurobi 进行优化计算时&#xff0c;合适的机器配置能够显著提升其求解性能&#xff0c;如何选择合适的硬件配置&#xff0c;主要从以下三个关键因素进行考虑&#xff1a; 1. CPU 主频和内存通道数 CPU 主频&#xff08;Clock Rate&#xff09; 是指处理器每秒钟能够执…

400行程序写一个实时操作系统(十三):调度器对象的创建与启动第一个任务

前言 调度器是整个RTOS的核心&#xff0c;在前面我们得到了调度器对象的框架图&#xff0c;并且简单介绍了调度器的原理。 在本节中&#xff0c;我们将会初始化调度器并且启动第一个任务。 本节内容需要一定的arm架构功底才能完全看懂&#xff0c;但是ARM架构只是RTOS这片大…

基于AI识别数据的Vue.js图像框选标注

在数字化时代&#xff0c;图像识别技术的应用越来越广泛&#xff0c;尤其是在车牌识别、人脸识别等领域。本文将介绍如何使用Vue.js框架和JavaScript创建一个交互式组件&#xff0c;该组件不仅允许用户在图片上绘制多个区域&#xff0c;加载文字&#xff0c;还提供了清空功能。…

leetcode-71-简化路径

题解&#xff1a; 1、以"/"作为分隔符对字符串进行分割得到数组names; 2、初始化一个栈stack&#xff08;python中的栈使用列表实现&#xff09;&#xff1b; 3、遍历数组names&#xff1b;如果当前元素为".."且栈不为空&#xff0c;则将弹出栈顶元素&a…

不考虑光影、背景、装饰,你的可视化大屏摆脱不了平淡。

如果在可视化大屏的设计中不考虑光影、背景和装饰&#xff0c;确实难以摆脱平淡。光影效果可以为大屏增添立体感和层次感&#xff0c;吸引观众的注意力。 合适的背景能营造出特定的氛围&#xff0c;使数据展示更具情境感。而装饰元素则可以起到点缀和美化的作用&#xff0c;提…

无人机悬停精度算法!

一、主要算法类型 PID控制算法&#xff1a; PID控制算法是一种常用的闭环控制算法&#xff0c;通过计算目标值与当前值的误差&#xff0c;并根据比例&#xff08;P&#xff09;、积分&#xff08;I&#xff09;、微分&#xff08;D&#xff09;三个参数来调整控制输出&#x…

049_python基于Python的热门微博数据可视化分析

目录 系统展示 开发背景 代码实现 项目案例 获取源码 博主介绍&#xff1a;CodeMentor毕业设计领航者、全网关注者30W群落&#xff0c;InfoQ特邀专栏作家、技术博客领航者、InfoQ新星培育计划导师、Web开发领域杰出贡献者&#xff0c;博客领航之星、开发者头条/腾讯云/AW…

Metasploit渗透测试之探索漏洞利用

概述 到目前为止&#xff0c;我们已经学习了如何利用漏洞&#xff0c;但不知道它们是如何工作的。尽管所有漏洞利用模块都经过了彻底验证&#xff0c;但了解它们的构建方式总是有好处的。作为渗透测试人员&#xff0c;知道如何编写自己的模块&#xff0c;或者简单地向现有模块…

【性能优化】安卓性能优化之CPU优化

【性能优化】安卓性能优化之CPU优化 CPU优化及常用工具原理与文章参考常用ADB常用原理、监控手段原理监控手段多线程并发解决耗时UI相关 常见场景排查CPU占用过高常用系统/开源分析工具AndroidStudio ProfilerSystraceBtracePerfettoTraceView和 Profile ANR相关ANR原理及常见场…

Android 图片相识度比较(pHash)

概述 在 Android 中&#xff0c;要比对两张 Bitmap 图片的相似度&#xff0c;常见的方法有基于像素差异、直方图比较、或者使用一些更高级的算法如 SSIM&#xff08;结构相似性&#xff09;和感知哈希&#xff08;pHash&#xff09;。 1. 基于像素的差异比较 可以逐像素比较…

Java基础-注解机制详解

文章目录 注解基础Java内置注解内置注解- Override内置注解 - Deprecated内置注解 - SuppressWarnings 元注解元注解 - Target元注解 - Retention & RetentionTarget元注解 - Documented元注解 - Inherited 注解与反射接口自定义注解 深入理解注解Java8提供了哪些新的注解&…

【React系列三】—React学习历程的分享

一、组件实例核心—Refs 通过定义 ref 属性可以给标签添加标识 字符串形式的Refs 这种形式已经不再推荐使用&#xff0c;官方不建议使用 https://zh-hans.legacy.reactjs.org/docs/refs-and-the-dom.html#legacy-api-string-refs 回调形式的Refs <script type"te…

nginx精讲

&#x1f939;‍♀️潜意识起点&#xff1a;个人主页 &#x1f399;座右铭&#xff1a;得之坦然&#xff0c;失之淡然。 &#x1f48e;擅长领域&#xff1a;前端 是的&#xff0c;我需要您的&#xff1a; &#x1f9e1;点赞❤️关注&#x1f499;收藏&#x1f49b; 是我持…

计算广告第三版pdf

需要该书pdf版本的同学点赞&#xff0c;私信我&#xff1a;

给哔哩哔哩bilibili电脑版做个手机遥控器

前言 bilibili电脑版可以在电脑屏幕上观看bilibili视频。然而&#xff0c;电脑版的bilibili不能通过手机控制视频翻页和调节音量&#xff0c;这意味着观看视频时需要一直坐在电脑旁边。那么&#xff0c;有没有办法制作一个手机遥控器来控制bilibili电脑版呢&#xff1f; 首先…

WPF MVVM模式实现DataGrid编辑

本文是一个MVVM模式开发的基础教程&#xff0c;完全手写实现&#xff0c;未借助三方框架&#xff0c;适用于初学者 要实现DataGrid的编辑&#xff0c;步骤如下&#xff1a; 1、创建两个窗口&#xff0c;第一个窗口用于显示DataGrid&#xff0c; 布局如下&#xff1a; 这个界…

(3) c++基本代码

main函数 main函数只有可执行程序才需要&#xff0c;如果是动态库等则无需main函数。 main函数标准的写法是 #include <iostream> using namspace std; int main(void) {// 业务代码return 0; } 当然以上代码只是最简单的案例&#xff0c;其中代表main函数值是int&#…