C++关联容器Map

本文介绍了C++中的关联容器Map,包括Map的定义、声明与初始化、基本操作以及常用成员函数。Map是一个键值对的集合,元素会根据键自动排序,不允许键重复。插入元素可以通过insert函数或下标操作符,访问元素可使用下标或迭代器。此外,文章还讨论了查找、删除及插入等操作。
摘要由CSDN通过智能技术生成

关联容器Map

一、定义

map是键-值对的集合,map中的所有元素都是pair,可以使用键作为下标来获取一个值。Map中所有元素都会根据元素的值自动被排序,同时拥有实值value和键值key,pair的第一元素被视为键值,第二元素被视为实值,同时map不允许两个元素有相同的键值。
用法:
包含头文件 #include<map>

二、声明及其初始化
map<key, value> m; //创建一个名为m的空map对象,其键和值的类型分别为key和value。
map<key, value> m(m2); //创建m2的副本m,m与m2必须有相同的键类型和值类型。
map<key, value> m(b,e); //创建map类型的对象m,存储迭代器b和e标记的范围内所有元素的副本。
map<key, value, comp> mp; //comp可选,为键值对存放策略。
三、基本操作

给map容器添加元素可通过两种方式实现:
1、通过insert成员函数实现。
2、通过下标操作符获取元素,然后给获取的元素赋值。
3、map对象的访问可通过下标和迭代器两种方式实现:map的下标是键,返回的是特定键所关联的值。
使用迭代器访问,iter->first指向元素的键,iter->second指向键对应的值。 使用下标访问map容器与使用下标访问vector不同:用下标访问map中不存在的元素将导致在map容器中添加一个新的元素,这个元素的键即为该下标值,键所对应的值为空。

map成员函数
不修改map对象的查询操作:

m.count(k);  // 返回m中键值等于k的元素的个数。
m.find(k);  // 如果m中存在按k索引的元素,则返回指向该元素的迭代器。

如果不存在,则返回结束游标end()。
对于map对象,由于map中不存在相同的两个或者多个键,所以count成员的返回值只能是0或者1,用于检查map对象中某键是否存在。find成员返回的是指向元素的迭代器,如果元素不存在,则返回end迭代器,用于读取元素而又不插入元素。

从map对象中删除元素:

m.erase(k);  // 删除m中键为k的元素,返回size_type类型的值,表示删除元素的个数。
m.erase(p);  // 从m中删除迭代器p所指向的元素,p必须指向m中确实存在的元素,而且不能等于m.end(),返回void类型。
m.erase(iterator first, iterator last);  // 删除一个范围,返回void类型。

map容器提供的插入操作:

m.insert(e) ;

e是一个用在m上的value_type类型的值。如果键e.first不在m中,则插入一个值为e.second的新元素;如果该键在m中已存在,那么不进行任何操作。该函数返回一个pair类型对象,包含指向键为e.first的元素的map迭代器,以及一个bool类型的对象,表示是否插入了该元素。

m.insert(beg, end);

beg和end是标记元素范围的迭代器,对于该范围内的所有元素,如果它的键在m中不存在,则将该键及其关联的值插入到m。 返回void类型。

m.insert(iter, e);

e是value_type类型的值,如果e.first不在m中,则创建新元素,并以迭代器iter为起点搜索新元素存储的位置,返回一个迭代器,指向m中具有给定键的元素。 在添加新的map元素时,使用insert成员可避免使用下标操作符带来不必要的初始化。

四、map的基本操作函数:
 begin()        // 返回指向map头部的迭代器
 clear(//删除所有元素
 count()         //返回指定元素出现的次数
 empty()         //如果map为空则返回true
 end()           //返回指向map末尾的迭代器
 equal_range()   //返回特殊条目的迭代器对
 erase()         //删除一个元素
 find()          //查找一个元素
 get_allocator() //返回map的配置器
 insert()        //插入元素
 key_comp()      //返回比较元素key的函数
 lower_bound()   //返回键值>=给定元素的第一个位置
 max_size()      //返回可以容纳的最大元素个数
 rbegin()        //返回一个指向map尾部的逆向迭代器
 rend()          //返回一个指向map头部的逆向迭代器
 size()          //返回map中元素的个数
 swap()           //交换两个map
 upper_bound()    //返回键值>给定元素的第一个位置
 value_comp()     //返回比较元素value的函数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值