C++ primer 关联容器

关联容器通过键(key)来存储和读取元素,顺序容器通过位置顺序存储和访问元素
两个基本的关联容器类型是set和map
这里写图片描述

关联容器共享大部分顺序容器的操作,不提供 front , push_front , pop_front , back ,push_back , pop_back 操作

map类型
map类型是键值对的集合,可以理解为关联数组,可使用键作为下标来获取一个值
使用map对象,不需包含map头文件,指明键和值的类型
这里写图片描述
对于键类型唯一的要求就是支持 < 操作符
这里写图片描述
对迭代器进行解引用将会获得一个引用,指向容器的一个value_type类型的值,对于map容器,其value_type类型是 pair 类型,它的first成员存放键,为const ,second成员存放值
键是不能修改的,只能改变值

给map添加元素
用下标访问不存在的元素会给map容器添加一个新的元素,它的键即为该下标值
下标操作符返回一个 mapped_type 类型的值

map < string ,int > word_count;
word_count["豆子"] =1

这里写图片描述

word_count.insert(map< string int >::value_type("douzi",1))
//简化传递给insert的实参
word_count.insert(make_pair("douzi",1))

查找并取用map中的元素
使用下标,但是使用下标比较危险,如果该键不在map容器中,那么下标操作会插入一个具有该键的新元素

这里写图片描述
这里写图片描述
从map中删除元素
这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值