9.9映射(map)

map的含义是“映射”。在数学上,映射是这样定义的:设A、B是两个集合,如果按照某种对应法则f,对于集合A中的任何一个元素,在集合B中都有唯一的元素和它对应,这样的对应叫做从集合A到集合B的映射。记作:f:A→B

因此,所谓map,就是能实现将一个值映射为另一个值的数据结构

map的另外一个含义是“键值对”,将键映射为值,键互不相同的,每个键都对应一个值,值可以是相同的

以下是一些“键值对”的例子

①一本英汉字典就是键值对的集合,在字典中收录了很多英文单词,每个英文单词都是互不相同的,单词就是键,单词的中文注解就是值字典就是将一个单词映射为它的注解,注解可以是相同的,比如cap的注解是“帽子”,hat的注解也是“帽子”。在Python语言中,的确有字典(dict)这种组合数据类型,而且Python语言中的字典就是“键值对”的集合。

②一个西文字符和它的ASCII编码就构成了一个键值对,键是互不相同的,当然在这个例子里,值也是互不相同的

③一个身份证号和姓名也构成了一个键值对,身份证号是互不相同的,但是姓名可以是相同的 

构造一个map的代码如下:
map<键的类型,值的类型>P;

可以通过“[ ]”操作符直接得到键映射的值,也可以通过赋值操作改变键映射的值,例如:p[key]=val
注意,map中的元素自动按键升序排序 

map常用的成员函数有:
①size():求元素个数
②empty():判断是否为空
③clear():清空
④begin():开始位置
⑤end():结束位置
⑤insert(x):将元素x插入到map中,其中x为一个键值对,可以用nake pairs生成一对数(即键值对)进行插入
p.insert(make_pair(key,val));
⑦erase(x):删除所有等于x的元素,其中x为键值对
⑧erase(it):删除t指向的元素,it为指向键值对的迭代器
⑨find(k):查找键为k的键值对的位置,若不存在,则返回尾指针 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值