2.9.1 引入

map相对于set区别,map具有键值和实值,所有元素根据键值自动排序。pair的第一元素被称为键值,第二元素被称为实值。map也是以红黑树为底层实现机制。


map/multimap区别:
map是根据key进行排序的所以,key是不能重复的。
multimap的key是可以重复的。

map常用API见map/multimap容器常用API

2.9.2 代码示例

map案列

text01

#include<iostream>
#include<map>
using namespace std; void text01()
{
//map容器模板参数,第一个参数key类型,第二个参数value类型
map<int, int> mymap; //插入数据 pair.first key的类型,第二个参数value类型。
//第一种
mymap.insert(pair<int, int>(10, 10));
pair < map<int, int>::iterator, bool> ret = mymap.insert(pair<int, int>(10, 100));
if (ret.second)
{
cout << "第一次插入成功" << endl;
}
else
{
cout << "插入失败!" << endl;
}
//第二种
mymap.insert(make_pair(20, 20));
//第三种
mymap.insert(map<int, int>::value_type(30, 30));
//第四种
mymap[40] = 40;
mymap[40] = 400;
//如果key不存在,创建pair插入到map容器中
//如果key存在,那么会修改key对应的value cout << mymap[60] << endl;//用[]访问map中不存在的key,会对改值默认初始化 //打印
for (map<int, int>::iterator it = mymap.begin(); it != mymap.end(); it++)
{
//*it取出来的是第一个pair
cout << "key:" << (*it).first << "value:" << it->second << endl;
}
} int main()
{
cout << endl << "text01:" << endl;
text01();
return 0;
}

text02

#include<iostream>
#include<map>
using namespace std; class MyKey
{
public:
MyKey(int index, int id)
{
this->mIndex = index;
this->mID = id;
}
public:
int mIndex;
int mID;
}; struct mycompare
{
bool operator()(const MyKey &key1,const MyKey &key2)const
{
return key1.mIndex > key2.mIndex;
}
}; void text02()
{
map<MyKey, int,mycompare> mymap;//自动排序,要告诉他怎么排序
mymap.insert(make_pair(MyKey(1, 2), 10));
mymap.insert(make_pair(MyKey(4, 5), 20)); for (auto it = mymap.begin(); it != mymap.end(); it++)
{
cout << it->first.mIndex << ":" << it->first.mID << "=" << it->second << endl;
}
} //text03这里没写
//主要是涉及lower_bound,upper_bound,equal_range. int main()
{
cout << endl << "text02:" << endl;
text02();
return 0;
}

multimap案列

multimap 案例
公司今天招聘了 5 个员工, 5 名员工进入公司之后,需要指派员工在那个部门工作
人员信息有: 姓名 年龄 电话 工资等组成
通过 Multimap 进行信息的插入 保存 显示
分部门显示员工信息 显示全部员工信息

#include <iostream>
#include <vector>
#include <map>
#include <string>
#include <time.h>
#include <stdlib.h>
using namespace std; #define SALE_DEPATMENT 1 // 销售部门
#define DEVELOP_DEPATMENT 2 // 研发部门
#define FINACIAL_DEPATMENT 3 // 财务部门 // multimap 案例
// 公司今天招聘了 5 个员工, 5 名员工进入公司之后,需要指派员工在那个部门工作
// 人员信息有: 姓名 年龄 电话 工资等组成
// 通过 Multimap 进行信息的插入 保存 显示
// 分部门显示员工信息 显示全部员工信息 class Worker
{
public:
string mName;
string mTele;
int mAge;
int mSalary;
}; // 创建员工
void Create_Worker(vector<Worker>& vWorker)
{
string seedName = "ABCDE";
for (int i = 0; i < 5; i++)
{
Worker worker;
worker.mName = "员工";
worker.mName += seedName.at(i);
worker.mAge = rand() % 10 + 20;
worker.mTele = "010-88888888";
worker.mSalary = rand() % 10000 + 10000;
// 保存员工信息
vWorker.push_back(worker);
}
} // 员工分组
void WorkerByGroup(vector<Worker>& vWorker, multimap<int, Worker>& workeGroup)
{
// 把员工随机分配到不同部门
srand(time(NULL));
for (vector<Worker>::iterator it = vWorker.begin(); it != vWorker.end(); it++)
{
int departID = rand() % 3 + 1;
switch (departID)
{
case SALE_DEPATMENT:
workeGroup.insert(make_pair(SALE_DEPATMENT, *it));
break;
case DEVELOP_DEPATMENT:
workeGroup.insert(make_pair(DEVELOP_DEPATMENT, *it));
break;
case FINACIAL_DEPATMENT:
workeGroup.insert(make_pair(FINACIAL_DEPATMENT, *it));
break;
default:
break;
}
}
} void showGroupWorkers(multimap<int, Worker>& workerGroup, int departID)
{
// find(key);//查找键 key 是否存在,若存在,返回该键的元素的迭代器;/若不存在,返回 map.end();
multimap<int, Worker>::iterator it = workerGroup.find(departID);
// 找当前部门总人数
// count(keyElem);//返回容器中 key 为 keyElem 的对组个数。对 map 来说,要么是 0,要么是 1。对multimap 来说,值可能大于 1。
int Departcount = workerGroup.count(departID);
int num = 0;
for (multimap<int, Worker>::iterator pos = it; it != workerGroup.end() && num < Departcount; pos++, num++)
{
cout << "姓名:" << pos->second.mName << " 年龄:" << pos->second.mAge << " 电话:" << pos->second.mTele << " 工资:" << pos->second.mSalary << endl;
}
} // 打印每一部分员工信息
void PrintWorkerByGroup(multimap<int, Worker>& workerGroup)
{
// 打印销售部门员工信息
cout << "销售部门:" << endl;
showGroupWorkers(workerGroup, SALE_DEPATMENT);
// 打印研发部门员工信息
cout << "研发部门:" << endl;
showGroupWorkers(workerGroup, DEVELOP_DEPATMENT);
// 打印财务部门员工信息
cout << "财务部门:" << endl;
showGroupWorkers(workerGroup, FINACIAL_DEPATMENT);
} int main()
{
// 存放新员工信息
vector<Worker> vWorker;
// multimap保存分组信息
multimap<int, Worker> workerGroup;
// 创建员工
Create_Worker(vWorker);
// 员工分组
WorkerByGroup(vWorker, workerGroup);
// 打印员工信息
PrintWorkerByGroup(workerGroup);
getchar();
return 0;
}

2.9.3 代码运行结果

map

multimap

总结

map也是非常常用的容器。参考本专题set的讲解,注意和unordered_map的区别。


谢谢阅读(〃’ ▽ '〃)如有纰漏欢迎指出,觉得还不错就点个赞吧。

最新文章

  1. [Unreal]学习笔记001
  2. Android手机总是提示:存储空间不足,解决方法
  3. CSS3学习之分享下transition属性
  4. HTTP状态代码含义
  5. Spring-Context之六:基于Setter方法进行依赖注入
  6. hdu 1016
  7. 《OD学hive》第六周20160731
  8. CentOS7 固定ip
  9. hdu2018
  10. centos6.5 apache+tomcat结合 负载均衡
  11. iframe父子窗口取值
  12. android3.2以上切屏禁止onCreate()
  13. [LeetCode] Search in Rotated Sorted Array [35]
  14. Oracle SqlPlus 方向键的方法和解决的退格键失效
  15. gsl安装(Linux系统)
  16. 解决 Cannot uninstall &#39;pyparsing&#39; 问题
  17. C#Stopwatch的简单计时zz
  18. Your project is not referencing the &quot;.NETPortable,Version=v4.5,Profile=Profile259&quot; framework. Add a reference to &quot;.NETPortable,Version=v4.5,Profile=Profile259&quot; in the &quot;frameworks&quot; section of your proj
  19. Win32汇编学习(6):键盘输入消息
  20. 【ShareCode】不错的技术文章 -- 如何使用异或(XOR)运算找到数组中缺失的数?

热门文章

  1. Mysql 占用字节大小
  2. DAG(有向无环图)技术
  3. sublime运行错误
  4. Solution -「ABC 213G」Connectivity 2
  5. WebGL 与 WebGPU比对[4] - Uniform
  6. Session是什么?它与Cookie有什么区别?
  7. 一个接口多个实现Spring如何实现正确注入
  8. 【论文考古】联邦学习开山之作 Communication-Efficient Learning of Deep Networks from Decentralized Data
  9. vue如何获取thymeleaf渲染的input值?
  10. 1. 堪比JMeter的.Net压测工具 - Crank 入门篇