C++ STL学习笔记 : 2. unordered map 容器

本文中,简单总结一下使用unordered map 的心得。unordered_map容器属于STL中关联表的一种,常用的map容器与unordered_map容器在使用中有着很大程度的相同点,在之后的文章中我可能会针对二者的相同点与不同点进行细致的分析,这里就不过多赘述,只是简单地和大家一起了解一下unordered_map的一些基本使用。
关联表作为STL库中的一类常见的容器,其结构和数组类似。与数组不同的是,关联表中有两个类型,键key索引类和被索引的元素类。Key值和元素的关系我们可以理解为映射关系。一个键值有且仅有一个对应的元素。
在这里插入图片描述
同时,关联表中使用的索引类,不再是简单的自然数,而是可以根据需要选择使用string字符串类,或自定义的类作为索引key的类型。不再使用自然数作为索引让关联表的使用相较于数组更加灵活,但需要注意的是,一个关联表中的所有键都应该是同一类型,所有被索引的元素也应该是同一类型。这两个类型在定义关联表的同时进行定义。下面我们就回到关联表中的一种容器,本篇文章的主角 : unordered_map的使用。

0.include相关库。

# include <unordered_map>

1.定义一个一维的unordered map:

第一部分,如何定义一个空的unordered_map容器。

unordered_map<uint64_t,string> mymap;
unordered_map<uint64_t,uint64_t> mymap2a
unordered_map<string,string>mymap3;

<>中的第一个参数是key的类型,第二个参数是对应的元素集的数据类型。unordered_map类可以理解为一个使用key作为角标标注的列表,只不过这个列表是无序的,且列表的序号也不再要求一定是正整数。与数组比较,unordered map等容器更加自由,更易于查找。

2.向unordered_map里添加项:

这个部分我们介绍一些向unordered_map里添加项的方法。

// 1. 使用insert方法
mymap.insert(make_pair(10,"nihao"));
mymap.insert(pair<uint64_t,string>(20,"hello"));
uint64_t ind = 30;
string toto = "hello";
mymap.insert(pair<uint64_t,string>(ind,toto));
//2. 使用角标直接赋值
mymap[40] = "nihaoma";

需要注意的是,一个key只能对应一个存储的数据。如果key已经存在了,使用insert方法对已存在的key进行插入操作不会覆盖之前key对应的值,而使用中括号,类似数组的赋值方法,例如mymap[10]="hahaha"可以覆盖已存在的key所对应的值。当然,如果使用中括号赋值时中括号中的key值在容器中不存在,那么此时中括号赋值的效果和使用insert方法一致,会为容器添加一个新的key 键,并插入对应的值。这一点在接下来我们使用二维unordered_map时还会进一步说明。

3.迭代器 iterator

由于unordered_map其中的项是没有顺序排列的,且键值可以不为正整数,因此为了对unordered_map中的每一项进行操作,且和数组一样满足我们遍历的需要,就必须使用迭代器。
迭代器的定义方法很简单,C<>::iterator name_iterator;
延续上述例子, 迭代器的定义方法代码如下:

unordered_map<uint64_t,string>::iterator ite_mymap;

迭代器可以使用容器的begin()或end()方法进行初始化 :

unordered_map<uint64_t,string>::iterator ite_mymap(mymap.begin());

迭代器可以理解为指向容器某一项的指针,每一项都包含一个key值和一个元素值,和指针一样,用*ite_mymap可以对迭代器取值。下述代码是一个简单的使用迭代器读取key值和元素值的例子:

#include <iostream>
#include <unordered_map>
using namespace std;
int main()
{unordered_map < uint64_t, uint64_t > mymap;mymap.insert(make_pair(10, 20));unordered_map < uint64_t, uint64_t >::iterator ite_mymap(mymap.begin());cout << (*ite_mymap).first<<endl;cout << (*ite_mymap).second << endl;cout << ite_mymap->first << endl;cout << ite_mymap->second << endl;return 0;
}

执行结果如下 :
在这里插入图片描述

通过上述代码以及执行结果我们不难看出,容器中的每一项,都包含有first和second两个属性,分别对应了key 键值和元素值。我们既可以通过指向项的迭代器指针读取这两个属性,同时也可以使用取值符号,直接通过项来读取这两个属性。

4. 使用迭代器遍历

有了在上述步骤中的认识,使用迭代器遍历容器也变得非常简单,使用一个for循环就可以遍历容器并利用迭代器进行操作了 :

for(ite_mymap=mymap.begin();ite_mymap!=mymap.end();ite_mymap++)
{...
}

5.二维unordered_map的使用

通过上面的几个部分,我们已经大致了解了一维unordered_map的使用。正如一开始我们提到的,unordered_map中被索引的元素类型可以是任意类,二维unordered_map实际就是被索引的元素集是令一个unordered_map类,这样就构成了二维的unordered_map。下面是一个简单的例子:

unordered_map<uint64_t, unordered_map<uint64_t, uint64_t>> mymap;
unordered_map<uint64_t, uint64_t> tmp;
tmp.insert(make_pair(10, 25));
mymap.insert(pair < uint64_t, unordered_map<uint64_t, uint64_t>>(10, tmp));
mymap[10][20] = 30;
mymap[10][40] = 35;
mymap[20][40] = 50;
unordered_map<uint64_t, unordered_map<uint64_t, uint64_t>>::iterator multitr;
unordered_map<uint64_t, uint64_t>::iterator intertr;
for(multitr=mymap.begin();multitr!=mymap.end();multitr++){for(intertr= multitr ->second.begin(); intertr != multitr ->second.end(); intertr ++)std::cout<< multitr ->first<<" "<<intertr->first<<" ("<< intertr -> second <<")"<<endl;}

输出结果如下 :
在这里插入图片描述
上述例子中,我们定义了unordered_map mymap,其键key类型为uint64_t,对应的元素类型为另一个unordered_map类。对于mymap来说,一个键对应一个unordered_map类的元素。对于二维unordered_map的遍历,我们定义两个迭代器,一个外部迭代器,一个内部迭代器。类似二维数组的遍历,我们使用for循环的嵌套来遍历二维的unordered_map。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/387000.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

tensorflow 安装在Anaconda

python环境&#xff1a;win10 64下anaconda4.2.0(python3.5)。安装tensorflow过程是在Anaconda Prompt中进行安装 1&#xff1a;打开Anaconda Prompt 在安装之前&#xff0c;说几个关于conda的小命令 conda list&#xff1a;可以显示已经安装好的库。 conda install 库名 &…

Dijkstra迪杰斯特拉算法 C++实现

本篇文章主要介绍了Dijkstra迪杰斯特拉算法的C实现&#xff0c;文章包含两个部分&#xff0c;在第一部分中我会简单介绍迪杰斯特拉算法以及一些个人的理解&#xff0c;第二部分会对C代码的逻辑进行解释。下面是我已经上传的代码资源&#xff0c;大家有兴趣的可以点击链接下载资…

Python开发一个股票类库

前言 使用Python开发一个股票项目。 项目地址&#xff1a; https://github.com/pythonstock/stock 相关资料&#xff1a; http://blog.csdn.net/freewebsys/article/details/78294566 主要使用开发语言是python。 使用的lib库是pandas&#xff0c;tushare&#xff0c;Tens…

C++ STL 学习笔记 3. 文本文件操作

本文主要总结了C中对文本文件的基本操作以及使用心得&#xff0c;第一部分中总结了C对文本文件的基本操作&#xff0c;第二部分中会以csv文件为例&#xff0c;进行读取存储由逗号分隔的字符串的操作。 1. 文本读取写入基础 要使用文件输入输出流&#xff0c;首先需要include相…

C# 调用python

1.C# 调用python 本质上是使用命令行运行python 1.1 C# 使用命令行 program.cs using System; using System.Diagnostics; using System.IO;namespace test {class Program{static void Main(string[] args){Program p new Program();string result p.run_cmd("ping…

python pandas serie简介及基本使用

本篇文章主要罗列了pandas模块中serie的基本使用。环境是jupyter notebook python 3.7。 serie是能够保存任何类型数据的一维数组&#xff0c;轴标签统称为索引&#xff0c;索引必须是唯一的散列且与数据的长度相同&#xff0c;默认情况下为np.arange(n)。 首先是import pand…

python pandas dataframe基本使用整理

dataframe是一种表格型的数据存储结构&#xff0c;可以看作是几个serie的集合。dataframe既有行索引&#xff0c;也有列索引。 以下代码环境为google colab/jupyter notebook。 接下来就对dataframe的基本使用进行整理。 dataframe也从属于pandas模块&#xff0c;因此还是老规矩…

常见开源分布式存储系统

对比说明 /文件系统 TFS FastDFS MogileFS MooseFS GlusterFS Ceph 开发语言 C C Perl C C C 开源协议 GPL V2 GPL V3 GPL GPL V3 GPL V3 LGPL 数据存储方式 块 文件/Trunk 文件 块 文件/块 对象/文件/块 集群节点通信协议 私有协议&#xff08;T…

机器学习理论梳理1: PCA主成分分析

机器学习的理论部分学习知识点比较乱且杂。我这里通过几篇文章&#xff0c;简单总结一下自己对机器学习理论的理解&#xff0c;以防遗忘。第一篇文章主要概述了机器学习的基本任务以及一个常用的降维方法&#xff0c;主成分分析。 机器学习的基本任务 机器学习能实现许多不同…

NLP基础 : HMM 隐马尔可夫模型

Hidden Markov Model, HMM 隐马尔可夫模型&#xff0c;是一种描述隐性变量(状态)和显性变量(观测状态)之间关系的模型。该模型遵循两个假设&#xff0c;隐性状态i只取决于前一个隐性状态i-1&#xff0c;而与其他先前的隐形状态无关。观测状态也只取决于当前的隐形状态。因此我们…

关于秒杀系统优化方向

今天听了一节咕泡学院的公开课&#xff0c;有收获。 秒杀系统的特点&#xff1a; 1.限时&#xff1b;2.限量供应&#xff1b;3.并发量大&#xff1b;如何优化&#xff1a; 1.客户端数据缓存。 2.CDN加速。 3.nginx动静分离&#xff0c;静态资源缓存&#xff0c;负载均衡。 4.se…

RUNOOB python练习题1

用来练手的python 练习题&#xff0c;原链接 : python练习实例1 题干 : 有四个数字&#xff1a;1、2、3、4&#xff0c;能组成多少个互不相同且无重复数字的三位数&#xff1f;各是多少&#xff1f; import numpy as np cen np.array([1,2,3,4]) tens np.array([1,2,3,4])…

MySQL 亿级数据需求的优化思路(一),交易流水记录的查询

对MySQL的性能和亿级数据的处理方法思考&#xff0c;以及分库分表到底该如何做&#xff0c;在什么场景比较合适&#xff1f; 比如银行交易流水记录的查询 限盐少许&#xff0c;上实际实验过程&#xff0c;以下是在实验的过程中做一些操作&#xff0c;以及踩过的一些坑&#…

RUNOOB python练习题2

用来练手的python 练习题&#xff0c;原链接 : python练习实例2 题干 : 企业发放的奖金根据利润提成。利润(I)低于或等于10万元时&#xff0c;奖金可提10%&#xff1b;利润高于10万元&#xff0c;低于20万元时&#xff0c;低于10万元的部分按10%提成&#xff0c;高于10万元的…

MySQL 亿级数据需求的优化思路(二),100亿数据,1万字段属性的秒级检索

最近在研究亿级数据的时候&#xff0c;无意中看到了一个关于写58同城的文章 https://blog.csdn.net/admin1973/article/details/55251499?fromtimeline 其实上面讲的versionext的方式以及压缩json的思路&#xff0c;对于我来讲都可以看得懂&#xff0c;想得通&#xff0c;其…

RUNOOB python练习题3

用来练手的python 练习题&#xff0c;原链接 : python练习实例3 拿到题目就写了如下代码&#xff0c;思路是因为使用**0.5进行开平方操作时&#xff0c;python会将数据类型自动转换为float单精度浮点型。这里利用提取其整数部分&#xff0c;来判断这个数是否是完全平方数。 z…

使用git将项目上传到github(最简单方法)

使用git将项目上传到github&#xff08;最简单方法&#xff09; 首先你需要一个github账号&#xff0c;所有还没有的话先去注册吧&#xff01; https://github.com/ 我们使用git需要先安装git工具&#xff0c;这里给出下载地址&#xff0c;下载后一路直接安装即可&#xff1…

RUNOOB python练习题4

用来练手的python习题其四&#xff0c; 原题链接: python练习实例4 题干: 输入某年某月某日&#xff0c;判断这一天是这一年的第几天&#xff1f; 这个题目比较简单&#xff0c;只需要注意闰年和非闰年的区别就可以了。我这里使用numpy矩阵存储每个月的天数&#xff0c;之后用…

GitHub入门:如何上传与下载工程?

由于经常要在家写代码&#xff0c;所以需要有个能够方便访问代码管理工具。最近尝试了一下GitHub。经过了一翻纠结之后&#xff0c;基本上掌握了他的使用方式。 要使用GitHub需要首先在其网站上进行注册。其官方网站是https://github.com/。注册的流程在这里就不多少了&#x…

如何解决PIP命令不可用

今天想用PIP装一个python包&#xff0c;发现PIP报错&#xff0c;不是内部或外部命令。。。 遇事百度&#xff0c;有两种说法&#xff0c;一&#xff0c;没安装包&#xff0c;不管那么多命令执行了再说 在命令行输入&#xff1a;python -m ensurepip 将pip.exe文件下载下来 再pi…