一、insert

◦1)用insert函数插入pair数据

◦map<int, string> mapStudent;

◦mapStudent.insert(pair<int, string>(1, “student_one”));

◦2)用insert函数插入value_type数据

◦map<int, string> mapStudent;

◦mapStudent.insert(map<int, string>::value_type (1, “student_one”));

◦3)用数组方式插入数据

◦map<int, string> mapStudent;

◦mapStudent[1]=“student1”;

◦mapStudent[2]=“student2”;

前两种如果插入相同的key,则插入失败,但是不会报错,例如

map<int,int> ss;
ss.insert(make_pair(1,1));
ss.insert(make_pair(1,2));

两次插入之后,ss[1]仍然为1.那么我们怎么知道是否插入成功了呢?

可以用pair来获得是否插入成功。
◦pair<map<int, string>::iterator, bool> Insert_Pair;
◦Insert_Pair = mapStudent.insert(map<int, string>::value_type (1, “student_one”));
◦我们通过pair的第二个变量来知道是否插入成功,它的第一个变量返回的是一个map的迭代器,如果插入成功的话Insert_Pair.second应该是true的,否则为false。

但是第三种会覆盖原先的值

map<int,int> ss;
ss[1]=1;
ss[1]=2;

两次插入之后,ss[1]wei 2.

二、根据key读map:

首先读取map最直观的方式是map[key],但是这样面临一个问题,可能这个key在map中根本不存在,因此在读取之前需要判断是否存在。

两种方式可以判断是否存在。

int num=map.count(key)

num=0: 不存在

num=1:存在

另一种是使用

map<type,type>::iterator iter;

iter=map.find(key);

if(iter!=map.end()){

  iter->second;//get data

}

三、遍历所有数据

map本身是红黑树,所以数据是有顺序的,可以使用两种顺序呢遍历,实际上就是树的中序遍历。

升序遍历是首先访问左子结点,降序遍历首先访问右子节点。

map<int,int> ss;
ss.insert(make_pair(,));
ss.insert(make_pair(,));
ss.insert(make_pair(,));
ss.insert(make_pair(,));
ss.insert(make_pair(,));
map<int,int>::iterator iter1;
for(iter1=ss.begin();iter1!=ss.end();iter1++){
cout<<iter1->first<<" "<<iter1->second<<endl;
}
cout<<endl;
map<int,int>::reverse_iterator iter2;
for(iter2=ss.rbegin();iter2!=ss.rend();iter2++){
cout<<iter2->first<<" "<<iter2->second<<endl;
}
cout<<endl;

结果为

四、数据的清空与判空

清空map中的数据可以用clear()函数,判定map中是否有数据可以用empty()函数,它返回true则说明是空map

五、数据的删除

这里要用到erase函数,它有三个重载了的函数,下面在例子中详细说明它们的用法

◦      1)如果要删除1, 用迭代器删除

◦       map<int, string>::iterator iter;

◦       iter = mapStudent.find(1);

◦       mapStudent.erase(iter);

◦       2)如果要删除1,用关键字删除

◦       Int n = mapStudent.erase(1);//如果删除了会返回1,否则返回0

◦       3)用迭代器,成片的删除

◦       //一下代码把整个map清空

◦       mapStudent.earse(mapStudent.begin(), mapStudent.end());

◦       //成片删除要注意的是,也是STL的特性,删除区间是一个前闭后开的集合

引用:

http://www.cnblogs.com/nzbbody/p/3409298.html

http://www.cnblogs.com/mattins/p/3531362.html

C++ map使用(基于RBTree)的更多相关文章

  1. String 转Map(基于Guava类库)

    字符串格式:key1=value1&key2=value2...... java代码 Map<String,String> targetOrderObj = Splitter.on ...

  2. 《python源代码剖析》笔记 python中的Dict对象

    本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie 1.PyDictObject对象 -->  C++ STL中的map是基于RB-tre ...

  3. 几种常见 容器 比较和分析 hashmap, map, vector, list ...hash table

    list支持快速的插入和删除,但是查找费时; vector支持快速的查找,但是插入费时. map查找的时间复杂度是对数的,这几乎是最快的,hash也是对数的.  如果我自己写,我也会用二叉检索树,它在 ...

  4. 《STL系列》之map原理及实现

    上一篇文章<STL系列>之vector原理及实现,介绍了vector的原理及实现,这篇文章介绍map的原理及实现.STL实现源码下载.STL中map的实现是基于RBTree的,我在实现的时 ...

  5. c++ map、vector、list

    总体来说,使用map最简单.支持查找,获取下标不存在也不会出错 map是使用rbtree结构, vector是用连续获取内存的方法,类似hash结构.list是链表结构, 不支持下标. map: 支持 ...

  6. Java 容器(list, set, map)

    java容器类库的简化图: (虚线框表示接口, 实线框表示普通的类, 空心箭头表示特定的类实现了接口, 实心箭头表示某个类可以生成箭头所指的类对象) 继承Collection的主要有Set 和 Lis ...

  7. Hash与Map

    Hash与Map 面试时经常被问到,什么是Hash?什么是Map? 答:hash采用hash表存储,map一般采用红黑树(RB Tree)实现.因此其memory数据结构是不一样的,而且他们的时间复杂 ...

  8. R(七): R开发实例-map热力图

    第四章通过REmap包完成基于map分布图示例,前面提到REmap基于Echart2.0, 一方面在移动终端适应效果差,另一方面REmap提供的热力图仅支持全国及省市大版块map,基于上面的原因,参考 ...

  9. map使用.xml

    map 是一种关联容器,  提供一对一的关联, 关联的形式为: KEY----VALUE     关键字不重复.multimap与map类似,但是允许关键字重复           即:关键字和与之对 ...

随机推荐

  1. JAVA设计模式之享元模式

    在阎宏博士的<JAVA与模式>一书中开头是这样描述享元(Flyweight)模式的: Flyweight在拳击比赛中指最轻量级,即“蝇量级”或“雨量级”,这里选择使用“享元模式”的意译,是 ...

  2. QTP实现功能测试的时候,当新版本的页面都改变了,应该如何解决

    去更改对象仓库的属性和更改对象仓库.

  3. Linux学习笔记——使用指定的用户权限执行程序——sudo

          sudo可以用来以其他用户身份执行命令,sudo命令可以针对单个命令授予临时权限.sudo仅在需要时授予用户权限,减少了用户因为错误执行命令损坏系统的可能性. 1:sudo的帮助信息如下: ...

  4. NHibernate系列文章十七:NHibernate Session管理(附程序下载)

    摘要 NHibernate的Session的管理涉及到NHibernate的两个最重要的对象ISessionFactory和ISession.ISessionFactory的生成非常消耗资源,通常都在 ...

  5. web测试特别点

    1.浏览器的后退按钮  提交表单一条已经成功提交的记录,back后再提交,看系统会如何处理.  检查多次使用back健的情况在有back的地方,back,回到原来的页面,再back,重复几次,看是否会 ...

  6. UVa 10071 - Back to High School Physics

    https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=94&page=s ...

  7. Lua __index元方法

    [Lua __index元方法] 当你通过键来访问 table 的时候,如果这个键没有值,那么Lua就会寻找该table的metatable(假定有metatable)中的__index 键.如果__ ...

  8. jdk代理和cglib代理

    1.jdk静态代理(静态代理和动态代理) 本质:在内存中构建出接口的实现类. 缺陷:只能对实现接口的类实现动态代理, 使用cglib可以对没有实现接口的类进行动态代理. 2.cglib动态代理     ...

  9. iOS中UITableView数据源刷新了,但tableview当中的cell没有刷新

    你会不会遇到通过断点查看数据源模型的确刷新了,但是tableview没有刷新的情况,我遇到了,并通过下面的方法解决了,供大家参考! 在tableview中的数据源代理方法 p.p1 { margin: ...

  10. ubuntu下安装迅雷

    ----------------------------------2016-03-28新增适用于ubuntu16.04系列的安装包---------------------------------- ...