4.3 map和multimap
使用map multimap必须包含头文件map
*:multimap
1)multimap定义
template<class Key,class Pred=less<Key>,class A=allocator<T>
class multimp
{
.....
typedef pair<const Key,T>value_type; //value_type经常用到
......
};
multimap每个对象都是pair模板类的对象。元素first成员变量也称关键字,其类型为Key。second成员变量也称值,类型为T。multimap容器里的元素是按照关键字从小到大排序的,且允许多个关键字相同。
上面multimap中的value_type实际上表示容器中的元素的类型。c++允许在类的内部定义类型。
2)成员函数
3)例
- //program 19.4.4.1 用multimap实现的学生信息管理程序
- #include <iostream>
- #include <map> //使用multimap需要包含此头文件
- #include <string>
- using namespace std;
- class CStudent
- {
- public:
- struct CInfo //类的内部还可以定义类
- {
- int id;
- string name;
- };
- int score;
- CInfo info; //学生的其他信息
- };
- typedef multimap<int,CStudent::CInfo> MAP_STD;
- int main()
- {
- MAP_STD mp;
- CStudent st;
- string cmd;
- while( cin >> cmd ) {
- if( cmd == "Add") {
- cin >> st.info.name >> st.info.id >> st.score ;
- mp.insert(MAP_STD::value_type(st.score,st.info ));
- }
- else if( cmd == "Query" ){
- int score;
- cin >> score;
- MAP_STD::iterator p = mp.lower_bound (score);
- if( p!= mp.begin()) {
- --p;
- score = p->first; //比要查询分数低的最高分
- MAP_STD::iterator maxp = p;
- int maxId = p->second.id;
- for( ; p != mp.begin() && p->first == score; --p) {
- //遍历所有成绩和score相等的学生
- if( p->second.id > maxId ) {
- maxp = p;
- maxId = p->second.id ;
- }
- }
- if( p->first == score) { //如果上面循环是因为 p == mp.begin()
- // 而终止,则p指向的元素还要处理
- if( p->second.id > maxId ) {
- maxp = p;
- maxId = p->second.id ;
- }
- }
- cout << maxp->second.name << " " << maxp->second.id << " "
- << maxp->first << endl;
- }
- else //lower_bound的结果就是 begin,说明没人分数比查询分数低
- cout << "Nobody" << endl;
- }
- }
- return ;
- }
**:map
1)定义
template<class Key,class T,class Pred=less<Key>,class A=allocator<T>>
class map {
......
typedef pair<const Key,T>value_type;
.......
};
map 和multimap十分相似,区别在于,map容器中的元素,关键字不能重复。
multimap有的成员函数map都有,此外map还有成员函数operator[]:
T&operator[](Key k);
该成员函数返回first值为k的元素的second部分。如果容器中没有元素的first值等于k,则自动添加值为k的元素;如果该元素的成员变量是一个对象,则用无参构造函数对其初始化。
2)例
- //program 19.4.5.1.cpp map的用法示例
- #include <iostream>
- #include <map> //使用map需要包含此头文件
- using namespace std;
- template <class T1,class T2>
- ostream & operator <<( ostream & o,const pair<T1,T2> & p)
- { //将pair对象输出为 (first,second)形式
- o << "(" << p.first << "," << p.second << ")";
- return o;
- }
- template<class T>
- void Print( T first,T last)
- {//打印区间[first,last)
- for( ; first != last; ++ first)
- cout << * first << " ";
- cout << endl;
- }
- typedef map<int,double,greater<int> > MYMAP; //此容器关键字是整型,
- //元素按关键字从大到小排序
- int main()
- {
- MYMAP mp;
- mp.insert(MYMAP::value_type(,2.7));
- pair<MYMAP::iterator,bool> p = mp.insert(make_pair(,99.3));
- if( ! p.second )
- cout << * (p.first) << " already exists" << endl; //会输出
- cout << "1) " << mp.count() << endl; //输出 1) 1
- mp.insert(make_pair(,9.3));
- cout << "2) " << mp[] << endl;//如果没有关键字为40的元素,则插入一个
- cout << "3) ";Print(mp.begin(),mp.end());//输出:3) (40,0)(20,9.3)(15,2.7)
- mp[] = 6.28; //把关键字为15的元素值改成6.28
- mp[] = 3.14; //插入关键字为17的元素,并将其值设为3.14
- cout << "4) ";Print(mp.begin(),mp.end());
- return ;
- }
4.3 map和multimap的更多相关文章
- STL的基本使用之关联容器:map和multiMap的基本使用
STL的基本使用之关联容器:map和multiMap的基本使用 简介 map 和 multimap 内部也都是使用红黑树来实现,他们存储的是键值对,并且会自动将元素的key进行排序.两者不同在于map ...
- STL之Map和multimap容器
1.Map和multimap容器 1)map是标准的关联式容器,一个map是一个键值对序列,即(key,value)对.它提供基于key的快速检索能力. 2)map中key值是唯一的.集合中的元素按一 ...
- C++ STL 学习笔记__(8)map和multimap容器
10.2.9 Map和multimap容器 map/multimap的简介 ² map是标准的关联式容器,一个map是一个键值对序列,即(key,value)对.它提供基于key的快速检索能力. ² ...
- STL Map和multimap 容器
STL Map和multimap 容器 map/multimap的简介 map是标准的关联式容器,一个map是一个键值对序列,即(key,value)对.它提供 基于key的快速检索能力. ...
- STL标准库-容器-map和multimap
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 map与multimap为关联容器,结构如下 map底层实现依然是rb_tree 他的data可以改,但是key不能改,因此ma ...
- STL中 map 和 multimap
1. 所在头文件<map>. 命名空间std, 声明如下: namespace std{ template <class Key,class T, class Compare = l ...
- 【C++ STL】Map和Multimap
1.结构 Map和multimap将key/value pair(键值/实值 队组)当作元素,进行管理.他们根据key的排序准则将元素排序.multimap允许重复元素,map不允许. 元素要求: k ...
- STL学习笔记— —容器map和multimap
简单介绍 在头文件<map> 中定义 namespace std { template <typename Key, typename T, typename Compare = l ...
- STL关联式容器之map和multimap
一,map和multimap的概念 1.map和multimap的基本知识 map是标准的关联式容器,一个map是一个键值对序列,即(key,value)对.它提供基于key的快速检索能力. map中 ...
随机推荐
- nginx 虚拟主机
基于域名的虚拟主机 创建站点目录 [root@nginx conf]# cd /usr/local/nginx/html/ [root@nginx html]# pwd /usr/local/ngin ...
- 【android-tips】如何在view中取得activity对象
(转载请注明出处:http://blog.csdn.net/buptgshengod) 今天想实现在view中返回上一个activity的功能,想了半天.因为在虽然view是包含于一个activity ...
- BZOJ2002——[Hnoi2010]Bounce 弹飞绵羊
1.题目大意:就是给一个动态的森林求size域 2.分析: 这个就是一个动态树问题,对于每一个位置i有i+ki这个父亲, 于是这就是一个森林了,然后对于每一个修改直接lct维护就好,询问就是i到最外面 ...
- eclipse pydev 跳转
[windows]-[Preference]-[Pydev]-[Interpreter-Python]-[Libraries]-system PYTHONPATH 全部加一遍,先加父目录,再加子目录.
- event相关
event.button 事件属性可返回一个整数,指示当事件被触发时哪个鼠标按键被点击. event.keyCode 事件属性可返回一个整数,指示当事件被触发时哪个键盘按键被点击. <scri ...
- SMT 的基本流程?SMT的工艺流程?SMT的设备操作?
一.SMT工艺流程------单面组装工艺来料检测 --> 丝印焊膏(点贴片胶)--> 贴片 --> 烘干(固化) --> 回流焊接 --> 清洗 --> 检测 - ...
- 第三方登录(QQ登录)开发流程详解
原文:http://www.cnblogs.com/it-cen/p/4338202.html 近排由于工作的繁忙,已经一个星期没写博文做分享了,接下来我对网站接入第三方登录----QQ登录的实现逻辑 ...
- poj 1035
http://poj.org/problem?id=1035 poj的一道字符串的水题,不难,但就是细节问题我也wa了几次 题意就是给你一个字典,再给你一些字符,首先如果字典中有这个字符串,则直接输出 ...
- 百度和google的区别
一.百度 二.google
- Java web 开发环境搭建
1.下载jdk-8u60-windows-i586.exe;安装过程会让指定jre的安装路径,此处最好指定和jdk安装一个目录下(D:\Program Files\Java\jdk1.8.0_60,D ...