c++ 关联容器-map和multimap容器

1. 介绍#includemap存储的是关键字-值对(key-value);提供基于key的快速检测能力。map中key是唯一的,集合根据key值进行排序(< 的比较方式)map中存储的key值的类型,默认使用 小于的比较方式(升序);如果是保存自定义的类型,需要传入自定义的比较规则函数map是由红黑树变体的平衡二叉树的数据结构实现的可以使用 [] 操作符访问key对应的valuemap的key是const类型的,不能对其修改multimap与map的区别:map的key是唯一
摘要由CSDN通过智能技术生成

1. 介绍

  • #include
  • map存储的是关键字-值对(key-value);提供基于key的快速检测能力。
  • map中key是唯一的,集合根据key值进行排序(< 的比较方式)
  • map中存储的key值的类型,默认使用 小于的比较方式(升序);如果是保存自定义的类型,需要传入自定义的比较规则函数
  • map是由红黑树变体的平衡二叉树的数据结构实现的
  • 可以使用 [] 操作符访问key对应的value
  • map的key是const类型的,不能对其修改

multimap与map的区别:

  • map的key是唯一的,而multimap的key可以重复
  • 由于multimap的key是可重复,即存在一对多的关系,因此不能使用 [] 操作符进行访问,即multimap不支持随机访问

2. 额外类型说明

关联容器定义了几种额外的类型,如下是map中这些类型的含义:
注意value_type对应的含义与其他类型的区别

类型名 含义
key_type 表示map中关键字(key)的类型
mapped_type 表示map中对应的值(value)的类型
value_type 表示map中一条数据的类型,即 pair<const key_type, mapped_type>,存放的键值对

注:pair类型讲解在以下链接中 https://blog.csdn.net/readyone/article/details/111491928

3. map/multimap的构造函数

默认构造方式:根据对应类型默认初始化
map<T1,T2> map1;
multimap<T1,T2> multimap1;

示例:

map<string, string> map_s;
multimap<string, int> map_si;

拷贝构造和赋值:

  • map(const map &mp); // 拷贝构造函数
  • map& operator=(const map &mp); //重载等号操作符
  • map.swap(mp); //交换两个集合

示例:

map<string, string> map1 = {
   {
   "jiek", "dfe"},
							{
   "dfei", "ieo"}};
 
map<string, string> map2 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值