map的专项知识点总结

标准库map类型是一种以键-值(key-value)存储的数据类型。以下分别从以下的几个方面总结:

(1).map对象的定义和初始化
(2).map对象的基本操作,主要包括添加元素,遍历等

map为pair类型(先了解pair类型)

(1)pair类型的定义和初始化

pair类型是在有文件utility中定义的,pair类型包含了两个数据值,通常有以下的一些定义和初始化的一些方法:

pair<T1, T2> p;///定义了一个空的pair对象p
pair<T1, T2> p(v1, v2);///定义了包含初始值为v1和v2的pair对象p
make_pair(v1, v2)///是以v1和v2值创建的一个新的pair对象
(2)pair对象的一些操作

除此之外,pair对象还有一些方法,如取出pair对象中的每一个成员的值:

p.first//p->first
p.second//p->second

例如:

#include <stdio.h>
#include <string.h>
#include <string>
#include<algorithm>
using namespace std;
int main()
{pair<int, string> p1(0, "Hello");printf("%d, %s\n", p1.first, p1.second.c_str());pair<int, string> p2 = make_pair(1, "World");printf("%d, %s\n", p2.first, p2.second.c_str());return 0;
}

map对象的定义和初始化

map是键-值对的组合,有以下的一些定义的方法:

map<k, v> m;///定义了一个名为m的空的map对象
map<k, v> m(m2);///创建了m2的副本m
map<k, v> m(b, e);///建了map对象m,并且存储迭代器b和e范围内的所有元素的副本。

map的value_type是存储元素的键以及值的pair类型,键为const。

map对象的一些基本操作

(1)map中元素的插入

在map中元素有两种插入方法:

(1)使用下标
(2)使用insert函数

在map中使用下标访问不存在的元素将导致在map容器中添加一个新的元素。

insert函数的插入方法主要有如下:
m.insert(e)///e一个value_type类型的值
m.insert(beg, end)///beg和end标记的是迭代器的开始和结束。
m.insert(iter, e)

两种插入方法如下面的例子所示:

#include <stdio.h>
#include <map>
using namespace std;
int main()
{map<int, int> mp;for (int i = 0; i < 10; i ++)mp[i] = i;for (int i = 10; i < 20; i++)mp.insert(make_pair(i, i));map<int, int>::iterator it;for (it = mp.begin(); it != mp.end(); it++)printf("%d-->%d\n", it->first, it->second);return 0;
}

(2)map中元素的查找和读取

注意:上述采用下标的方法读取map中元素时,若map中不存在该元素,则会在map中插入。
因此,
(1)若只是查找该元素是否存在,可以使用函数count(k),该函数返回的是k出现的次数;
(2)若是想取得key对应的值,可以使用函数find(k),该函数返回的是指向该元素的迭代器。

上述的两个函数的使用如下所示:

#include <stdio.h>
#include <map>
using namespace std;
int main()
{map<int, int> mp;for (int i = 0; i < 20; i++)mp.insert(make_pair(i, i));if (mp.count(0))printf("yes!\n");elseprintf("no!\n");map<int, int>::iterator it_find;it_find = mp.find(0);if (it_find != mp.end())it_find->second = 20;elseprintf("no!\n");map<int, int>::iterator it;for (it = mp.begin(); it != mp.end(); it++)printf("%d->%d\n", it->first, it->second);return 0;
}

(3)从map中删除元素

从map中删除元素的函数是erase(),该函数有如下的三种形式:

m.erase(k)///删除的是m中键为k的元素,返回的是删除的元素的个数;
m.erase(p)///删除的是迭代器p指向的元素,返回的是void;
m.erase(b, e)///删除的是迭代器b和迭代器e范围内的元素,返回void。

如下所示:

#include <stdio.h>
#include <map>
using namespace std;
int main()
{map<int, int> mp;for (int i = 0; i < 20; i++)mp.insert(make_pair(i, i));mp.erase(0);mp.erase(mp.begin());map<int, int>::iterator it;for (it = mp.begin(); it != mp.end(); it++)printf("%d->%d\n", it->first, it->second);return 0;
}

见大佬博客

C/C++STL常用容器用法总结

https://blog.csdn.net/weixin_41162823/article/details/79759081

c++ 关联容器用法详解(set与map)

https://blog.csdn.net/weixin_41162823/article/details/80185444#t1

map的专项知识点总结相关推荐

  1. Shaolin HDU - 4585(map模板题)

    题意: 少林寺有n+1个和尚,他们都有一个独有的编号和战斗力值,当一个年轻人通过所有考试并被宣布为少林的新僧人时,将会有一场战斗,作为欢迎的一部分.新和尚必须与一位战斗等级最接近他的战斗等级的老和尚战 ...

  2. 理解关联容器“map”的关键点

    map有一个构造函数: map<k, v> m(b, e); <C++ Primer>解释为:"创建 map 类型的对象 m, 存储迭代器 b 和 e 标记的范围内所 ...

  3. 2022哈工大软件构造lab1小结(知识点)

    哈工大软件构造lab1小结 提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 问题一 使用的库 异常处理机制 字符串内容检查 写入文件 问题二 problem 3:画一 ...

  4. c++关联容器的成员函数find的一个例子

    先来一个灰色难懂的部分镇楼. #include <string> #include <iostream> #include <list> #include < ...

  5. uva11991 Easy Problem from Rujia Liu?

    题目链接. 分析: <算法竞赛入门经典--训练指南>上的一道例(水)题,map的应用,个人感觉代码中注释掉的那一句没有什么意义,就注释掉了,提交确实也对了. map的小知识点(总结自c++ ...

  6. forth day ---内置函数、匿名函数

    一.内置函数: 画思维导图迭代器中:range next iterlocals() 本地的命名空间globals() 全局的命名空间 # def func(): # a = 1 # b = 2 # p ...

  7. 44道javaScript变态题(上)

    转自:https://github.com/xiaoyu2er/blog/issues/1 原题来自: javascript-puzzlers 读者可以先去做一下感受感受. 当初笔者的成绩是 21/4 ...

  8. 尺取法(图文解析、初学推荐)

    文章目录 最少连续页(poj3320) 分析题意 第一步:找第一个满足条件区间 第二步:开始将左端边界向右移,达到"缩小"区间.减少连续页的目的. 归纳总结代码 尺取法:顾名思义, ...

  9. JavaScript专题(一)变量提升与预编译,一起去发现Js华丽的暗箱操作

    JavaScript之变量与函数提升 相信阅读完<前端进阶系列>的朋友们已经对Js中经典的知识点有所了解.本系列的第一篇选择了一个值得讨论的问题--变量提升,我们会从遇到问题.分析问题.解 ...

最新文章

  1. django 的ORM
  2. 卧槽,又一款Markdown组合神器!!!
  3. eclipse中hibernate和mybatis中xml配置文件的没有标签提醒解决方法
  4. mysql trim 索引_mysql强大的trim()函数
  5. HALCON示例程序color_fuses_lut_trans.hdev通过颜色对保险丝进行分类
  6. 使用Selenium进行Spring Boot集成测试
  7. python prettytable_让python的print变得更好看——prettytable和colorama
  8. Python基础知识有哪些?你都知道吗
  9. linux 取消nologin_Linux中nologin的应用 转
  10. Python练习-装饰器版-为什么我的用户总被锁定
  11. MyBatis——MyBatis Generator插件使用(配置详解)
  12. WidsMob ImageConvert for Mac(图片格式转换器)
  13. ORACLE SQL优化大全
  14. 基于HTML的旋转立方体的实现
  15. beyond compare如何设置只比较实际内容?(使用关联规则比较)
  16. 【高级持续性威胁追踪】当黑客不讲武德,安全专家也容易被骗
  17. 【蓝凌表单】流程表单JS汇总
  18. 乡愁!根之所在,情之所系!
  19. 接口测试——HtmlUnit、OkHttp
  20. 岁月如沙容颜易逝,年关将至的感伤你有吗?

热门文章

  1. C和指针之编译出现warning: implicit declaration of function ‘matrix_multiply‘ is invalid in C99问题
  2. C++之map的前后遍历
  3. linux c之assert函数使用总结
  4. Android之DrawText详解
  5. mysql数据库密码为空_注意MySQL数据库用户root密码为空
  6. java对象引用出错_“Java有值传递和引用传递”为什么错了?
  7. 这是哪里来的小妖精!!!
  8. 可以自发热的袜子,穿上暖3.9℃,这个冬天不再怕脚冷!
  9. 这些数学趣图,数学老师看了后会怎么想?
  10. 深度学习会不会被取代?深度学习必看发展史