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 库名 &…

伯努利数学习笔记的说...

经过一天的学习&#xff0c;我们发现伯努利数是个非常有用 &#xff08;个屁&#xff09; 的数列 定义 但是...伯努利数是什么呢&#xff1f;我们先给伯努利数一个定义&#xff1a; 令 \(B(i)\) 表示 伯努利数第 i 项&#xff0c;那么有&#xff1a; \[\sum_{i0}^{n} \begin{pm…

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…

LeetCode 105. Construct Binary Tree from Preorder and Inorder Traversal 由前序和中序遍历建立二叉树 C++...

LeetCode 105. Construct Binary Tree from Preorder and Inorder Traversal 由前序和中序遍历建立二叉树 C Given preorder and inorder traversal of a tree, construct the binary tree. Note:You may assume that duplicates do not exist in the tree. For example, given…

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…

4-17

1、html 中div class是什么&#xff1f; 在这里我将用id与class的比较&#xff0c;让这个问题更容易理解&#xff08;1&#xff09;、使用区别id具有唯一性&#xff0c;在一个网页中同一个命名只能使用一次&#xff1b;class命名的类可以在一个网页中使用无数次。&#xff08;2…

python pandas serie简介及基本使用

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

Linux系统中nc工具那些不为人知的用法

Linux nc命令用法 参考地址&#xff1a;https://www.cnblogs.com/jjzd/p/6306273.html -g<网关>&#xff1a;设置路由器跃程通信网关&#xff0c;最多设置8个; -G<指向器数目>&#xff1a;设置来源路由指向器&#xff0c;其数值为4的倍数; -h&#xff1a;在线帮助;…

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…

[十二省联考2019]皮配

题目链接 选一个派系和一个阵营可以唯一确定一名导师 因为每一个阵营里的导师都分别来自不同派系&#xff0c;所以k0时&#xff0c;对阵营的选择是不影响对派系的选择的 唯一的限制就是同城市的要在同一个阵营 所以以每个城市为物品&#xff0c;物品大小为该城市的人数&#xf…

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

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

29 _react-router说明

一、SPA的理解 1.单页面web应用(single page web application ,SPA) 2.整个应用只有一个完整的页面 3.点击页面中的链接不会刷新页面&#xff0c;本身也不会向服务器发请求 4.当点击路由链接时&#xff0c;只会做页面的局部更新 5.数据都需要通过ajax请求获取&#xff0c;并在前…

Java程序员如何快速理解Kubernetes

我们希望微服务是可复制的&#xff0c;可替换的工作节点&#xff0c;这样可以轻松进行升级或降级&#xff0c;同时无需任何停机时间&#xff0c;并花费最少代价的管理。我们可以说我们希望他们成为我们的小黄人&#xff08;minions&#xff09;。本文我们将通过一个简单的例子来…

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…

Mysql插入很慢,找到了稍微快点的方法

MYSQL批量插入数据库实现语句性能分析 假定我们的表结构如下 代码如下 CREATE TABLE example ( example_id INT NOT NULL, name VARCHAR( 50 ) NOT NULL, value VARCHAR( 50 ) NOT NULL, other_value VARCHAR( 50 ) NOT NULL ) 通常情况下单条插入的sql语句我们会这么写&…

Linux - 时间相关命令 - ntpdate, date, hwclock

1. 概述 最近也不知道写啥了, 把之前的老文档整理一下, 凑个数什么的配置时间这种工作, 偶尔还是要用一下主要描述 3 个命令的简单适用 ntpdatehwlock2. ntpdate 1. 概述 用于同步时钟的命令2. 机制 通常是有一个服务器对外提供时间客户端可以与时间服务器同步ntp 是他们之间交…