map容器(不能直接对map进行自定义排序)
- 所有元素会根据键值自动排序,每一个元素都是pair(同时拥有键值和实值),pair中:第一个元素被认为是键值,第二个元素被认为是实值。
- map容器的键值不可变,实值可变。
- 常用的API:
map<T1,T2> mapTT;/ /map默认构造函数:
map(const map &mp);/ /拷贝构造函数
map赋值操作
map& operator=(const map &mp) ;
swap (mp) ;
map大小操作
size() ;/ /返回容器中元索的数目
empty();/ /判断容器是否为空
map插入数据元索操作
map.insert(...); / /往容器插入元索,返回pair<iterator ,bool>
map<int,string> mapStu;
mapStu. insert(pair<int,string>(3, "小张"));
mapStu. inset(make_ pair(-1, "校长")) ;
mapStu.insert(map<int,string>::value_type(111,"xxx"));
mapStu[3] ="小刘";
mapStu[5] = "小王";
map删除操作
clear();
erase(pos) ;
erase(beg,end) ;
erase (keyElem) ;
map查找操作
find(key);
count (keyElem) ;
lower_bound (keyElem) ;
upper_bound (keyElem) ;
equal_range (keyElem) ;
map<int,string> m;
m.insert(pair<int,string>(9527 ,"星爷")) ;
m.insert(make_pair(10086, "移动")) ;
m.insert (map<int,string>::value_type(10010, "联通")) ;
m[10000] ="电信";
for_each(m.begin() ,m.end() ,[] (pair<int,string> val) {
cout<<"key="<<val. first<<",value="<<val. second<<end1;});
- 用第四种方法访问map容器时:cout<<m[n]<<endl;,必须保证容器中有该键值,否则会创建一个实值为空的键值。
- 遍历方式:
void myPrintMap01 (map<int,string> &m)
{
for (map<int,string>: :const_iterator it = m.begin() ;it!=m.end() ;it++)
{
cout<<"key="<<(*it) . first<<",value="<<(*it) . second<<end ;
}
}
map<int,string> ::const_iterator ret;
ret = m.find(10086) ;
{
cout<<"术找到相关节点"<<endl;
}
else
{
cout<<"找到相关节点:key="<< (*ret). first<<", value="<<(*ret).second <<endl;
}
maltimap