1、Map的常用用法

map:映射。可以将任何基本类型,结构体,STL容器映射到任何基本类型包括容器。

使用map,需要加map的头文件,#include<map>和using namespace std;

1.1、map的定义

map<typename1,typename2> mp;
map<string,int> mp;
//如果是字符串到int的映射,必须使用string不能使用char数组。

1.2、map容器元素的访问

map的两种访问方式:下标访问、迭代器访问

1.2.1、下标访问

和访问数组一样。map中键是唯一的

1.2.2、迭代器访问

map<typename1,typename2>::iterator it;

#include<stdio.h>
#include<map> using namespace std; int main()
{
map<char,int> mp;
mp['a']=;
mp['b']=;
mp['d']=;
mp['c']=;
mp['c']=;//20被覆盖
printf("%d\n",mp['c']);
for(map<char,int>::iterator it=mp.begin();it!=mp.end();it++)
{
printf("%c %d\n",it->first,it->second);//it->first:当前映射的键,it->second:当前映射的值
}
//a 5
//b 10
//c 30
//d 40
//map会以键从小到大的顺序自动排序。map内部是使用红黑树实现的,set内部也是。
//建立映射的时候,会自动实现从小到大的排序功能
return ;
}

1.3、map常用函数

1.3.1、find()

find(key):返回键为key的映射,时间复杂度为O(logN)

1.3.2、erase()

删除单个元素:

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

mp.erase(key):key为删除元素的键,时间复杂度为O(logN)

删除区间内的元素,左闭右开[start,end)

1.3.3、size()
1.3.4、clear()

用来清空map,复杂度为O(N)

#include<stdio.h>
#include<map> using namespace std; int main()
{
map<char,int> mp;
mp['a']=;
mp['b']=;
mp['d']=;
mp['c']=;
mp['c']=;//20被覆盖
printf("%d\n",mp['c']);// mp.erase('b');//删除键为b的映射,也就是b 10
for(map<char,int>::iterator it=mp.begin();it!=mp.end();it++)
{
printf("%c %d\n",it->first,it->second);
}
//a 5
//c 30
//d 40
map<char,int>::iterator it=mp.find("a");
mp.erase(it);//删除a 5
for(map<char,int>::iterator it=mp.begin();it!=mp.end();it++)
{
printf("%c %d\n",it->first,it->second);
}
//c 30
//d 40
mp['e']=;
mp['f']=;
map<char,int>::iterator it=mp.find("d");
mp.erase(it,mp.end());//删除区间, d 40 e 50
return ;
}

1.4、map的常见用途

a、建立字符或者字符串与整数之间的映射的时候,使用map

b、判断大整数或者其他类型数据是否存在的时候,map可以当bool数组用

c、字符串和字符串的映射

2018-09-25 19:20:09

@author:Foreordination

C++标准模板库(STL)之Map的更多相关文章

  1. 标准模板库(STL)学习探究之stack

    标准模板库(STL)学习探究之stack queue priority_queue list map/multimap dequeue string

  2. C++ 标准模板库(STL)

    C++ 标准模板库(STL)C++ STL (Standard Template Library标准模板库) 是通用类模板和算法的集合,它提供给程序员一些标准的数据结构的实现如 queues(队列), ...

  3. STL学习系列之一——标准模板库STL介绍

    库是一系列程序组件的集合,他们可以在不同的程序中重复使用.C++语言按照传统的习惯,提供了由各种各样的函数组成的库,用于完成诸如输入/输出.数学计算等功能. 1. STL介绍 标准模板库STL是当今每 ...

  4. 标准模板库--STL

    标准模板库STL 1.泛型程序设计 C++ 语言的核心优势之一就是便于软件的重用 C++中有两个方面体现重用: 1.面向对象的思想:继承和多态,标准类库 2.泛型程序设计(generic progra ...

  5. 标准模板库(STL)学习探究之vector容器

    标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...

  6. C++的标准模板库STL中实现的数据结构之顺序表vector的分析与使用

    摘要 本文主要借助对C++的标准模板库STL中实现的数据结构的学习和使用来加深对数据结构的理解.即联系数据结构的理论分析和详细的应用实现(STL),本文是系列总结的第一篇,主要针对线性表中的顺序表(动 ...

  7. 实验8 标准模板库STL

    一.实验目的与要求: 了解标准模板库STL中的容器.迭代器.函数对象和算法等基本概念. 掌握STL,并能应用STL解决实际问题. 二.实验过程: 完成实验8标准模板库STL中练习题,见:http:// ...

  8. C++的标准模板库STL中实现的数据结构之链表std::list的分析与使用

    摘要 本文主要借助对C++的标准模板库STL中实现的数据结构的学习和使用来加深对数据结构的理解,即联系数据结构的理论分析和详细的应用实现(STL),本文是系列总结的第二篇.主要针对线性表中的链表 ST ...

  9. C++ 标准模板库STL 队列 queue 使用方法与应用介绍

    C++ 标准模板库STL 队列 queue 使用方法与应用介绍 queue queue模板类的定义在<queue>头文件中. 与stack模板类很相似,queue模板类也需要两个模板参数, ...

  10. 【c++】标准模板库STL入门简介与常见用法

    一.STL简介 1.什么是STL STL(Standard Template Library)标准模板库,主要由容器.迭代器.算法.函数对象.内存分配器和适配器六大部分组成.STL已是标准C++的一部 ...

随机推荐

  1. centos7安装pip

    转自:https://www.cnblogs.com/mangoVic/p/6428369.html 默认情况下,centos7是没有pip的,可以通过如下命令安装 首先安装epel扩展源: yum ...

  2. eclipse端口号冲突解决办法

    解决办法如下: 1.打开cmd 2.输入 netstat   -ano|findstr  8080  然后按回车键(8080对应你的端口号) 3.输入 taskkill  /pid  6856  /f ...

  3. SQL语句——exists和in区别

    表结构及数据 user表 order表 in select * from table A where id in (xxxxxxxxxxx):满足条件的数据会被查出来: 先查询子查询的表,然后将内表. ...

  4. Gradle目录结构详解

    环境:window 7 64 Gradle 版本: gradle 3.0 创建文件夹,并初始化 mkdir gradle_dir && cd gradle_dir gradle ini ...

  5. 用PIL库进行图像处理

    一.如果系统里没有安装PIL库的,请先到命令提示符输入“pip install pillow”进行安装 二.之后就可以参考以下的代码 from PIL import Image from pylab ...

  6. 洲阁筛 & min_25筛学习笔记

    洲阁筛 给定一个积性函数$F(n)$,求$\sum_{i = 1}^{n}F(n)$.并且$F(n)$满足在素数和素数次幂的时候易于计算. 显然有: $\sum_{i = 1}^{n} F(n) = ...

  7. Bresenham算法

    1 算法原理 基本原理从某处摘得:设直线方程为yi+1=yi+k(xi+1-xi)+k.假设列坐标象素已经确定为xi,其行坐标为yi.那么下一个象素的列坐标为xi+1,而行坐标要么为yi,要么递增1为 ...

  8. LintCode 1.A+B的问题

    LintCode 1.A+B的问题 描述 给出两个整数 a 和 b , 求他们的和. 答案 public class Solution { /** * @param a: An integer * @ ...

  9. scipy插值与拟合

    原文链接:https://zhuanlan.zhihu.com/p/28149195 1.最小二乘拟合 实例1 import numpy as np import matplotlib.pyplot ...

  10. React点击操作自动定位到另外一个元素

    使用Ref 方式一 使用ScrollIntoView方法 import React from 'react' export default class ScrollToElement extends ...