我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何在c++中使用map结构

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何在c++中使用map结构

如何在c++中使用map结构?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

map的常用用法

map 表示映射,可以将任何基本类型(包括 STL 容器)映射到任何基本类型(包括 STL 容器),例如可以建立如 int 到 double,string 到 int 的映射等。

map 提供一对一的 hash,该功能类似 Python 的字典:

  • 第一个称为键( key ),每个关键字只能在 map 中出现一次;

  • 第二个称为该键的值( value );

1. 头文件

<bits/stdc++.h> 头文件已经包括了该头文件。

2. 定义

定义 map 如下,参数的第一个为 key 的类型,第二个为 value 的类型。

map<typename1, typename2> mp;

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

map 的键和值也可以是 STL 容器,例如可以将一个 set 容器映射到一个字符串:

map<set<int>, string> mp;

3. map 容器内元素的访问

(1)通过下标访问

注意:map 的键是唯一的。

#include <iostream>#include <map>using namespace std;int main(){    map<char, int> mp;    mp['c'] = 30;     cout << mp['c'] << endl;     return 0;}

30

(2)通过迭代器访问

定义迭代器:

map<typename1, typename2>::iterator it;

这样可以得到迭代器 it,map 可以使用 it->first来访问键,使用 it->second 来访问值。

#include <stdio.h>#include <map>using namespace std;int main(){    map<char, int> mp;    mp['m'] = 20;    mp['r'] = 30;    mp['a'] = 40;    for(map<char, int>::iterator it = mp.begin(); it!=mp.end();it++){        printf("%c %d\n", it->first, it->second);    }    return 0;}

输出:

a 40
m 20
r 30

【注意】map 会以键从小到大的顺序自动排序。迭代器的比较不能用 < 或者 >,而只能使用 == 或者 !=

(3)通过逆向迭代器访问

#include <stdio.h>#include <map>using namespace std;int main(){    map<char, int> mp;    mp['m'] = 20;    mp['r'] = 30;    mp['a'] = 40;    for(map<char, int>::reverse_iterator it = mp.rbegin(); it!=mp.rend();it++){        printf("%c %d\n", it->first, it->second);    }    return 0;}

输出:

r 30
m 20 
a 40

rbegin()指向 map 的最后一个元素,rend()指向 map 第一个元素之前。

4. map 元素的插入

(1)通过insert + <key, value> 插入

map<int, string> mapStudent;  mapStudent.insert(pair<int, string>(1, "student_one"));

(2)通过insert + 迭代器 插入

map<int, string> mapStudent;  mapStudent.insert(map<int, string>::value_type (1, "student_one"));

(3)通过数组方式插入

map<int, string> mapStudent;  mapStudent[1] = "student_one";

【注意】第一、二种方法完全等价,但是第三种和前两种有所区别。当映射中包含了键,则第一、二中方法插入失败,而第三种方法会覆盖之前的键值对。所以先后插入相同 key 的元素,第一、二种方法会保留第一次的数据,第三种会保留最后一次的。

5. map 常用函数实例解析

(1)find()

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

#include <stdio.h>#include <map>using namespace std;int main(){    map<char, int> mp;    mp['a'] = 1;    mp['b'] = 2;    mp['c'] = 3;    map<char, int>::iterator it = mp.find('b');    printf("%c %d\n", it->first, it->second);    return 0;}

b 2

(2)erase()

① 删除单个元素

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

#include <stdio.h>#include <map>using namespace std;int main(){    map<char, int> mp;    mp['a'] = 1;    mp['b'] = 2;    mp['c'] = 3;    map<char, int>::iterator it = mp.find('b');    mp.erase(it);  // 删除 b 2    for(map<char, int>::iterator it = mp.begin(); it!=mp.end();it++){        printf("%c %d\n", it->first, it->second);    }    return 0;}

a 1
c 3

mp.erase(key):key是要删除的映射的键,时间复杂度为 O(logN)

#include <stdio.h>#include <map>using namespace std;int main(){    map<char, int> mp;    mp['a'] = 1;    mp['b'] = 2;    mp['c'] = 3;    mp.erase('b');  // 删除 b 2    for(map<char, int>::iterator it = mp.begin(); it!=mp.end();it++){        printf("%c %d\n", it->first, it->second);    }    return 0;}

a 1
c 3

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

mp.erase(first, last):first 为需要删除区间的起始迭代器,last 为需要删除的区间的末尾迭代器的下一个地址,即删除左闭右开区间 [first, last) 内所有元素。

#include <stdio.h>#include <map>using namespace std;int main(){    map<char, int> mp;    mp['a'] = 1;    mp['b'] = 2;    mp['c'] = 3;    map<char, int>::iterator it = mp.find('b');  // 令it指向键为b的映射    mp.erase(it, mp.end());  // 删除it之后所有的映射    for(map<char, int>::iterator it = mp.begin(); it!=mp.end();it++){        printf("%c %d\n", it->first, it->second);    }    return 0;}

a 1

(3)size()

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

#include <stdio.h>#include <map>using namespace std;int main(){    map<char, int> mp;    mp['a'] = 10;    mp['b'] = 20;    mp['c'] = 30;    printf("%d\n", mp.size());  // 3对映射    return 0;}

(4)count()

count(): 返回 map 中对应键的个数,由于 map 中相同键只能最多有一个,所以 count() 的结果只能是 0 或者 1。

#include <iostream>#include <map>int main (){  std::map<char,int> mymap;char c;mymap ['a']=101;mymap ['c']=202;mymap ['d']=303;for (c='a'; c<'e'; c++){  std::cout << c;  if (mymap.count(c)>0)    std::cout << " is an element of mymap.\n";  else     std::cout << " is not an element of mymap.\n";}return 0;}

结果:

a is an element of mymap.
b is not an element of mymap.
c is an element of mymap.
d is an element of mymap.

(5)clear()

clear(): 用于清空 map,map变为初始的空状态。

(6)empty()

empty():判断 map 是否为空,如果 map 为空,返回 true,否则返回 false.

(7)lower_bound() 、upper_bound()

lower_bound() : 返回键值 >= 给定元素的第一个位置。即如果键的类型可以比较,可以使用二分查找的方法,返回的类型是一个迭代器。 upper_bound(): 返回键值>给定元素的第一个位置。即如果键的类型可以比较,可以使用二分查找的方法,返回的类型是一个迭代器。

map<int, string> mapStudent;  mapStudent[1] = "student_one";  mapStudent[3] = "student_three";  mapStudent[5] = "student_five"; map<int, string>::iterator iter;iter = mapStudent.lower_bound(2); // 返回键值为3的迭代器;iter = mapStudent.upper_bound(2); // 返回键值为3的迭代器

看完上述内容,你们掌握如何在c++中使用map结构的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网行业资讯频道,感谢各位的阅读!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何在c++中使用map结构

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在c++中使用map结构

如何在c++中使用map结构?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。map的常用用法map 表示映射,可以将任何基本类型(包括 STL 容器)映射到任何基本类型(包括 S
2023-06-14

C#中如何使用结构体

这期内容当中小编将会给大家带来有关C#中如何使用结构体,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。例如C++中定义的以下结构体:struct RCEStruct { int Event; in
2023-06-18

C++中如何使用结构体

这篇文章给大家介绍C++中如何使用结构体,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。结构体(struct)是由一系列具有相同类型或不同类型的数据构成的数据集合,也叫结构。建议大家可以和这篇文章结合着来看,C++的中的
2023-06-17

C#中如何使用结构体构造函数

本篇文章给大家分享的是有关C#中如何使用结构体构造函数,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。///〈summary〉 ///启动服务端的参数结构 ///〈/summ
2023-06-17

如何在Golang中有效修改Map数据结构

在Golang中,Map是一种非常常用的数据结构,它能够存储键值对,并提供快速的查找功能。在使用Map时,经常会遇到需要修改Map中的数据的情况。但是在修改Map数据时,需要注意一些细节,以确保数据的准确性和可靠性。本文将详细介绍如何在Go
如何在Golang中有效修改Map数据结构
2024-03-02

C++中map和set如何使用

这篇文章主要介绍了C++中map和set如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C++中map和set如何使用文章都会有所收获,下面我们一起来看看吧。一、set1.1 set的介绍首先要知道set
2023-07-05

如何在Java中使用单if结构

这篇文章将为大家详细讲解有关如何在Java中使用单if结构,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Java的优点是什么1. 简单,只需理解基本的概念,就可以编写适合于各种情况的应用程序
2023-06-14

C语言中的结构体如何使用

本篇内容介绍了“C语言中的结构体如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!结构体的声明结构体的定义:结构体是一些值的集合,这些值
2023-07-02

如何在AmazeUi 中使用树形结构

如何在AmazeUi 中使用树形结构?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。第一步:基本引入2023-06-09

如何在C语言中使用多维数组和结构体

如何在C语言中使用多维数组和结构体?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1887 颜色精简题目:有一个颜色集合,里面有若干个颜色值(RBG系统表示)。现
2023-06-15

C++中的map容器如何使用

这篇“C++中的map容器如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++中的map容器如何使用”文章吧。一、m
2023-07-05

C语言结构体如何使用

本文小编为大家详细介绍“C语言结构体如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言结构体如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。本质一些值的集合。简单使用#include
2023-06-30

如何在Java中使用switch分支结构

如何在Java中使用switch分支结构?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编
2023-06-15

如何使用C++中的数据结构函数?

如何使用C++中的数据结构函数?数据结构是计算机科学中的重要概念,它涉及如何组织和存储数据以便有效地访问和操作。C++是一种强大的编程语言,提供了许多内置的数据结构函数,开发人员可以使用这些函数来创建、操作和管理不同类型的数据结构。在本文中
如何使用C++中的数据结构函数?
2023-11-18

ES6新数据结构Map功能如何用

这篇文章主要介绍“ES6新数据结构Map功能如何用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“ES6新数据结构Map功能如何用”文章能帮助大家解决问题。新数据结构MapJavaScript中对象的
2023-06-17

C语言中结构体和共用体如何使用

本篇文章给大家分享的是有关C语言中结构体和共用体如何使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。结构体 / struct结构体的定义声明一个结构体类型的一般形式为:str
2023-06-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录