• map的定义
map<typename1, typename2> mp;

  map需要确定映射前类型和映射后类型,所以需要在<>内填写两个类型,第一个是键的类型,第二个是值的类型。

  注:如果是字符串到整型的映射,必须使用string而不能使用char数组。

map<string, int> mp;
  • map容器内元素的访问

  map可以通过下标访问或通过迭代器访问。

  (1)通过下标访问

 1 #include <iostream>
2 #include <map>
3 using namespace std;
4 map<char, int> mp;
5 int main()
6 {
7 mp['a']=1;
8 mp['c']=2;
9 cout<<mp['c'];
10 return 0;
11 }
输出结果:
2

  (2)通过迭代器访问

  map迭代器的定义:

map<typename1, typename2>::iterator it;

  map可以使用it->first来访问键,使用it->second来访问值。

  实例:

 1 #include <iostream>
2 #include <map>
3 using namespace std;
4 map<char, int> mp;
5 int main()
6 {
7 mp['a']=1;
8 mp['c']=2;
9 mp['b']=3;
10 for(map<char, int>::iterator it=mp.begin();it!=mp.end();it++){
11 cout<<it->first<<" "<<it->second<<endl;
12 }
13 return 0;
14 }
输出结果:
a 1
b 3
c 2

  从上面例子我们可以看出,map会以键从小到大的顺序自动排序。这是由于map内部是使用红黑树实现的(set也是)。

  • map常用函数

  (1)find()

  find(key)返回键值为key的映射的迭代器,时间复杂度为O(logN),N为map中映射的个数。

 1 #include <iostream>
2 #include <map>
3 using namespace std;
4 map<char, int> mp;
5 int main()
6 {
7 mp['a']=1;
8 mp['c']=2;
9 mp['b']=3;
10 map<char, int>::iterator it=mp.find('c');
11 cout<<it->first<<" "<<it->second;
12 return 0;
13 }
输出结果:
c 2

  (2)erase()

  erase()可以删除单个元素,也可以删除一个区间的所有元素。

  ①删除单个元素

  mp.erase(it),it为需要删除的元素的迭代器,时间复杂度为O(1)。

 1 #include <iostream>
2 #include <map>
3 using namespace std;
4 map<char, int> mp;
5 int main()
6 {
7 mp['a']=1;
8 mp['c']=2;
9 mp['b']=3;
10 map<char, int>::iterator it=mp.find('c');
11 mp.erase(it);
12 for(map<char, int>::iterator it=mp.begin();it!=mp.end();it++){
13 cout<<it->first<<" "<<it->second<<endl;
14 }
15 return 0;
16 }
输出结果:
a 1
b 3

  mp.erase(key),key为欲删除的映射的键。时间复杂度为O(logN),N为map内元素的个数。

 1 #include <iostream>
2 #include <map>
3 using namespace std;
4 map<char, int> mp;
5 int main()
6 {
7 mp['a']=1;
8 mp['c']=2;
9 mp['b']=3;
10 mp.erase('c');
11 for(map<char, int>::iterator it=mp.begin();it!=mp.end();it++){
12 cout<<it->first<<" "<<it->second<<endl;
13 }
14 return 0;
15 }
输出结果:
a 1
b 3

  ②删除一个区间内的所有元素

 1 #include <iostream>
2 #include <map>
3 using namespace std;
4 map<char, int> mp;
5 int main()
6 {
7 mp['a']=1;
8 mp['c']=2;
9 mp['b']=3;
10 map<char, int>::iterator it=mp.find('c'); //令it指向键为c的值
11 mp.erase(it, mp.end()); //删除it之后的所有映射
12 for(map<char, int>::iterator it=mp.begin();it!=mp.end();it++){
13 cout<<it->first<<" "<<it->second<<endl;
14 }
15 return 0;
16 }
输出结果:
a 1
b 3 

  (3)size()

  size()用来获得map中映射的对数,时间复杂度为O(1)。

 1 #include <iostream>
2 #include <map>
3 using namespace std;
4 map<char, int> mp;
5 int main()
6 {
7 mp['a']=1;
8 mp['c']=2;
9 mp['b']=3;
10 cout<<mp.size();
11 return 0;
12 }
输出结果:
3

  (4)clear()

  clear()用来清除map中的所有元素,时间复杂度为O(N)。

 1 #include <iostream>
2 #include <map>
3 using namespace std;
4 map<char, int> mp;
5 int main()
6 {
7 mp['a']=1;
8 mp['c']=2;
9 mp['b']=3;
10 mp.clear(); //清空map
11 cout<<mp.size();
12 return 0;
13 }
输出结果:
0

最新文章

  1. VR技术的高速发展阶段
  2. android版微信5.2.1更新 支持微信聊天记录备份到电脑上
  3. linux学习之——学习路线(摘抄)
  4. 在Windows2008系统中利用IIS建立FTP服务器
  5. C++静态成员变量和静态成员函数小结
  6. Linux基础(二)
  7. C# 经典入门15章 -TabControl
  8. [Swift]LeetCode259.三数之和较小值 $ 3Sum Smaller
  9. MYSQL转换编码的解决方法
  10. laravel框架的注入
  11. java输入输出流(I/O)总结
  12. redis使用规范文档 20170522版
  13. lldb使用
  14. centos7-vmware克隆后的配置
  15. contos 7创建阿里云镜像源
  16. Oracle11g口令过期的解决
  17. RulersGuides.js – 网站中实现 Photoshop 标尺效果
  18. 使用jedis2.8.0连接redis
  19. XRP共识算法
  20. Right-BICEP 测试四则运算程序

热门文章

  1. LA3213加密
  2. Windows核心编程 第十一章 线程池的使用
  3. Java中实现某方法和重写某方法的区别
  4. vscode 终端操作命令npm报错
  5. python多进程、多线程服务器和客户端的简单实现
  6. 【软工】个人项目作业——个人软件流程(PSP)
  7. 重新整理 .net core 实践篇————配置应用[一]
  8. Java集合详解(一):全面理解Java集合
  9. 【Cocos2d-x】屏蔽Emoji并解决由于Emoji导致的崩溃问题
  10. jQuery清空元素和克隆元素