unordered_map 与 unordered_set 的使用

news2024/9/27 12:17:07

unordered_map

unordered_map 的介绍文档

unordered_map 的介绍文档:来自cpluscplus.com 的中文翻译

  1. unordered_map是存储<key, value>键值对的关联式容器,其允许通过keys快速的索引到与
    其对应的value。
  2. 在unordered_map中,键值通常用于惟一地标识元素,而映射值是一个对象,其内容与此
    键关联。键和映射值的类型可能不同。
  3. 在内部,unordered_map没有对<kye, value>按照任何特定的顺序排序, 为了能在常数范围内
    找到key所对应的value,unordered_map将相同哈希值的键值对放在相同的桶中。
  4. unordered_map容器通过key访问单个元素要比map快,但它通常在遍历元素子集的范围迭
    代方面效率较低。
  5. unordered_maps实现了直接访问操作符(operator[]),它允许使用key作为参数直接访问
    value。
  6. 它的迭代器至少是前向迭代器。

unordered_map 是 C++11 的语法,C++98 是没有 unordered_map

构造函数

unordered_map 存储的数据是:key-value 的结构,因此实例化 unordered_map 需要传入两个模板参数。unordered-map 的底层数据结构是哈希表。unordered_map 数据 key-value 形式的存储你可以理解为哈希表存储了一个 pair 。传入的第一个模板参数就是 pair 的 first,传入的第二个模板参数就是 pair 的 second。

  • unordered_map 可以无参构造,这是在做算法题用的比较多的。
  • unordered_map 可以使用 initializer_list 来初始化。initializer_list 是 C++11 的语法。
#include<iostream>
#include<unordered_map>
using namespace std;

int main()
{
    unordered_map<int, int> hash1; //这是无参构造
    unordered_map<int, int> hash2({{1,1}, {2,2}, {3,3}}); //这是使用initializer_list来构造
    return 0;
}

bool empty() const

这个函数用来判断哈希表是否为空,为空返回 true;否则返回 false。

#include<iostream>
#include<unordered_map>
using namespace std;

int main()
{
    unordered_map<int, int> hash1; //这是无参构造
    unordered_map<int, int> hash2({{1,1}, {2,2}, {3,3}}); //这是使用initializer_list来构造

    cout << hash1.empty() << endl; //输出:1

    cout << hash2.empty() << endl; //输出:0
    return 0;
}

size_t size() const

这个函数用来获取哈希表中有效元素的个数。

#include<iostream>
#include<unordered_map>
using namespace std;

int main()
{
    unordered_map<int, int> hash1; //这是无参构造
    unordered_map<int, int> hash2({{1,1}, {2,2}, {3,3}}); //这是使用initializer_list来构造

    cout << hash1.size() << endl; //输出:1

    cout << hash2.size() << endl; //输出:3
    return 0;
}

迭代器

  • begin:返回哈希表中第一个元素的位置对应的迭代器。
  • end:返回的迭代器并不指向任何元素,而是指向容器中最后一个元素之后的位置。因此,返回的值不应被取消引用。
    有了 begin 和 end 迭代器,我们就可以遍历 unordered_map 了。
#include<iostream>
#include<unordered_map>
using namespace std;

int main()
{
    unordered_map<int, int> hash2({{10,10}, {20,20}, {30,30}}); //这是使用initializer_list来构造
    auto it = hash2.begin();
    while(it != hash2.end())
    {
        cout << it->first << " " << it->second << endl;
        ++it;
    }
    return 0;
}

在这里插入图片描述
我们看到最后遍历得到的结果与插入的顺序并不相同。这也证明了 unordered_map 是一个无序容器。仅仅存储一个 key-value 的数据。

const V& operator[](const K& key)

这个函数和 mapoperator[] 很像。
如果 key 与容器中某个元素的键相匹配,函数会返回其映射值(value)的引用。

如果 key 与容器中任何元素的键不匹配,函数将插入一个具有该键的新元素,并返回其映射值的引用。请注意,即使没有为元素分配映射值(元素是使用默认构造函数构造的),容器的大小也会增加一个。

#include<iostream>
#include<unordered_map>
using namespace std;

int main()
{
    unordered_map<int, int> hash2({{10,10}, {20,20}, {30,30}}); //这是使用initializer_list来构造

    cout << hash2[10] << endl; //输出:10

    hash2[40]; // 使用 operator[] 访问key为 40 的元素,但是不存在,会插入一个 key 为 40 的元素,value我们没有指定,那么会调用 value 类型的默认构造函数:int() 作为 40 这个 key 值的 value 值

    cout << hash2[40] << endl; //输出:0
    return 0;
}

iterator find(const K& key)

unordered_map 中查找 key,如果查找成功返回该位置对应的迭代器,如果查找失败,那么返回 unordered_map::end ,就是 end 迭代器。
下面的代码中,我们使用 find 查找一个元素,通过得到的迭代器访问他的 value。

#include<iostream>
#include<unordered_map>
using namespace std;

int main()
{
    unordered_map<int, int> hash2({{10,10}, {20,20}, {30,30}}); //这是使用initializer_list来构造
	
	auto it = hash2.find(10);
    if(it == hash2.end()) cout << "此元素不存在" << endl;
    else cout << it->second << endl; //输出:10

    return 0;
}

size_t count(const K& key) const

搜索容器中键为 key 的元素,并返回找到的元素个数。由于 unordered_map 容器不允许键重复,这意味着如果容器中存在键为 key 的元素,函数实际返回 1,否则返回 0。

#include<iostream>
#include<unordered_map>
using namespace std;

int main()
{
    unordered_map<int, int> hash2({{10,10}, {20,20}, {30,30}}); //这是使用initializer_list来构造

    cout << hash2.count(10) << endl; //输出:1
    cout << hash2.count(40) << endl; //输出:0

    return 0;
}

pair<iterator, bool> insert ( const pair<K, V>& kv )

这个函数和 mapinsert 完全一样。
你可以向 unordered_map 中插入一个键值对。
函数返回一个 pair 对象,其第一个元素是一个迭代器,指向容器中新插入的元素或键等价的元素,另一个 bool 值表示该元素是否插入成功。

#include<iostream>
#include<unordered_map>
using namespace std;

int main()
{
    unordered_map<int, int> hash2({{10,10}, {20,20}, {30,30}}); //这是使用initializer_list来构造

    pair<unordered_map<int, int>::iterator, bool> ret1 = hash2.insert(make_pair(40, 40));
    cout << "插入成功与否:" << ret1.second << endl; //插入成功,ret1.second 为 1

    pair<unordered_map<int, int>::iterator, bool> ret2 = hash2.insert(make_pair(30, 0));
    cout << ret2.first->second << endl; //插入失败,得到的是原 key 为 30 的元素对应的 value:30 而不是新插入的 0

    return 0;
}

insert 函数也可以插入 initializer_list 和构造函数那里一样:
hash2.insert({60,60})

erase 函数

erase 有三个重载的版本:
在这里插入图片描述

  • 第一个版本:删除一个迭代器位置的元素。
  • 第二个版本:删除键为 k 的元素。
  • 第三个版本:删除一个迭代器区间。
#include<iostream>
#include<unordered_map>
using namespace std;

int main()
{
    unordered_map<int, int> hash2({{10,10}, {20,20}, {30,30}}); //这是使用initializer_list来构造

    hash2.erase(hash2.begin()); //第一个版本

    hash2.erase(30); //第二个版本

    hash2.erase(hash2.begin(), hash2.end()); //第三个版本

    return 0;
}

void clear() const

清空 unordered_map 中所有的元素。

#include<iostream>
#include<unordered_map>
using namespace std;

int main()
{
    unordered_map<int, int> hash2({{10,10}, {20,20}, {30,30}}); //这是使用initializer_list来构造

    hash2.clear();

    cout << hash2.size() << endl; // 输出:0

    return 0;
}

unordered_set

这是 unordered_set 的介绍文档:来自 cpluscplus.com。

  • unordered_set 是一种不按特定顺序存储唯一元素的容器,可以根据元素的值快速检索单个元素。

  • 在 unordered_set 中,元素的值同时也是其键,可以唯一地识别该元素。键是不可变的,因此,unordered_set 中的元素一旦进入容器就不能修改,但可以插入和移除。

  • 在内部,unordered_set 中的元素不按任何特定顺序排序,而是根据它们的哈希值组织成桶,以便直接按其值快速访问单个元素(平均时间复杂度不变)。

  • 无序集容器在按键访问单个元素时比集合容器更快,但在对元素子集进行范围迭代时,其效率通常较低。

  • 容器中的迭代器至少是前向迭代器。

unordere_set 存储的数据只有一个 key。
unordered_set 与 unordered_map 的接口完全相同。这里就不再赘述了。

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

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

相关文章

码云 -- 本地代码上传到码云

1. 在码云上创建远程仓库 复制远程仓库地址 2. 在本地代码上创建 git 仓库 在本地代码文件夹上&#xff0c;打开git 命令窗口 输入初始化命令&#xff0c;创建 git 仓库 git init3. 给 git 仓库添加远程仓库 继续输入 git 命令 git remote add origin 远程仓库地址4. 按 git 的…

数字逻辑电路基础-时序逻辑电路之触发器

文章目录 一、D触发器二、verilog源码三、综合及仿真结果一、D触发器 本文介绍数字逻辑电路中常用的基础时序逻辑电路触发器。它有记忆和存储信息功能,触发器是边沿触发电路。 下图是触发器常用表示方式(时钟上升沿有效): 触发器由两个锁存器组成,前级是主锁存器,后级…

Git工作流和Commit规范

Git大家都非常熟悉了&#xff0c;就不做过多介绍&#xff0c;但是如何用好Git、如何进行合理的分支开发、Merge你是否有一个规范流程呢&#xff1f;&#x1f4a4; 不论是一个团队一起开发一个项目&#xff0c;还是自己独立开发一个项目&#xff0c;都少不了要和Git打交道&…

C++学习笔记——static对象

一、static对象——累计创建了多少对象和正在使用的对象数目 static更多的是作为一个介入类的一个第三方成员变量。 声明为static的类成员称为类的静态成员&#xff0c;用static修饰的成员变量&#xff0c;称之为静态成员变量&#xff1b; 用static修饰的成员函数&#xff0c;称…

JS逆向之wasm逆向(二)

本文仅供技术交流和技术学习 不做其他用途 接着上一篇继续讲&#xff1a; 上篇地址&#xff1a; JS逆向之wasm逆向(二进制) 网址&#xff1a; aHR0cHM6Ly93d3cuN3E2Y3lqLmNvbTo5MDAxL3JlZ2lzdGVyNDY5Njg/aV9jb2RlPTQ0Mjc5OTU1 这个网站我们后面可以继续讲他的debugger 和滑块…

Spring Boot 整合MyBatis-Plus 详解

MyBatis-Plus (opens new window)&#xff08;简称 MP&#xff09;是一个 MyBatis (opens new window)的增强工具&#xff0c;在 MyBatis 的基础上只做增强不做改变&#xff0c;为简化开发、提高效率而生。 全新的 MyBatis-Plus 3.0 版本基于 JDK8&#xff0c;提供了 lambda 形…

【数据结构】树和二叉树详解

目录 1. 前言2. 树概念及结构2.1. 树的概念2.2. 与树有关的一些概念2.3. 树与非树2.4. 树的表示 3. 二叉树概念及结构3.1. 二叉树概念3.2. 特殊的二叉树3.3. 二叉树的性质3.4 二叉树的存储结构3.4.1 顺序存储3.4.2 链式存储 3.5 堆 1. 前言 在前面我们一起了解的数据结构有顺序…

振南技术干货集:制冷设备大型IoT监测项目研发纪实(6)

注解目录 1.制冷设备的监测迫在眉睫 1.1 冷食的利润贡献 1.2 冷设监测系统的困难 &#xff08;制冷设备对于便利店为何如何重要&#xff1f;了解一下你所不知道的便利店和新零售行业。关于电力线载波通信的论战。&#xff09; 2、电路设计 2.1 防护电路 2.1.1 强电防护 …

初识JVM(简单易懂),解开JVM神秘的面纱

目录 一、什么是JVM&#xff08;Java虚拟机&#xff09;&#xff1f; 二、JVM的功能 三、JVM的功能-即时编译 四、常见的JVM 五、JVM的组成 五、JVM的工作流程 参考资料 一、什么是JVM&#xff08;Java虚拟机&#xff09;&#xff1f; 在Java的世界里&#xff0c;Java虚…

【实验】配置用户自动获取IPv6地址的案例

【赠送】IT技术视频教程&#xff0c;白拿不谢&#xff01;思科、华为、红帽、数据库、云计算等等​编辑https://xmws-it.blog.csdn.net/article/details/117297837?spm1001.2014.3001.5502https://xmws-it.blog.csdn.net/article/details/117297837?spm1001.2014.3001.5502【…

云贝教育 |【技术文章】PG的缓存管理器原理

PG的缓存管理器原理 缓冲区管理器管理共享内存和持久存储之间的数据传输 &#xff0c; 它会对 DBMS 的性能产生重大影响。 PostgreSQL 缓冲区管理器工作非常高效。 本章介绍 PostgreSQL 缓冲区管理器。第一部分提供概述 &#xff0c;后续部分描述以下主题&#xff1a; 缓冲…

OSG动画与声音-路径动画之导出与导入(2)

路径的导出示例 路径的导出示例的代码如程序清单10-2所示。 1. // 创建路径 2. osg::ref_ptr<osg::AnimationPath> createAnimationPath(osg::Vec3 ¢er, 3. float radius, float looptime) 4. { 5. // 创建一个Path对象 6. osg::ref_ptr<…

【史上最细教程】服务器MySQL数据库完成主从复制

文章目录 MySQL完成主从复制教程准备&#xff1a;原理&#xff1a;步骤&#xff1a; 推荐文章 MySQL完成主从复制教程 主从复制&#xff08;也称 AB 复制&#xff09;就是将一个服务器&#xff08;主服务器&#xff09;的数据复制到一个或多个MySQL数据库服务器&#xff08;从…

云安全之盾:ZStack 云主机安全防护解决方案全方位保护云环境

随着云计算的蓬勃发展&#xff0c;网络威胁愈发复杂&#xff0c;涵盖了从勒索病毒到APT攻击的各种威胁类型。在这一风云变幻的网络安全环境下&#xff0c;云主机安全不再仅仅是一个选项&#xff0c;它是信息系统安全的核心要素。云轴科技ZStack 云主机安全防护解决方案是为了满…

java项目之品牌银饰售卖平台(ssm+vue)

项目简介 主要功能包括首页、个人中心、用户管理、促销活动管理、饰品管理、我的收藏管理、系统管理、订单管理等。管理员模块: 管理员可以查询、编辑、管理每个用户的信息和系统管理员自己的信息&#xff0c;同时还可以编辑、修改、查询用户账户和密码&#xff0c;以及对系统…

项目管理套路:看这一篇绝对够用❤️

写论文必不可少的&#xff0c;就是创建代码并进行实验。好的项目管理可以让实验进行得更加顺利。本篇博客以一次项目实践为例&#xff0c;介绍项目管理的方法&#xff0c;以及可能遇到的问题&#xff0c;并提供一些可行的解决方案。 目录 项目管理工具开始第一步版本管理十分关…

微信小程序:This Mini Program cannot be opened as your Weixin version is out-of-date.

项目场景&#xff1a; 问题描述 升级基础库3.2.0&#xff0c;然后PC端整个小程序都打不开了&#xff0c;点击小程序提示”This Mini Program cannot be opened as your Weixin version is out-of-date. Update Weixin to the latest version.“&#xff0c;并且点击Update Wei…

成为AI产品经理——模型构建流程(下)

目录 1.模型训练 2.模型验证 3.模型融合 4.模型部署 上节课我们讲了模型设计、特征工程&#xff0c;这节课我们来讲模型构建剩下的三个部分&#xff1a;模型训练、模型验证和模型融合。 1.模型训练 模型训练就是要不断地训练、验证、调优直至让模型达到最优。 那么怎么达…

Linux系统装宝塔面板提示磁盘空间不足如何清理,检测到当前磁盘超过80%,空间不足如何清理

Linux系统装宝塔面板提示磁盘空间不足如何清理&#xff0c;检测到当前磁盘超过80%&#xff0c;空间不足如何清理 今天登陆服务器查看到磁盘空间满&#xff0c;如题这部分属于运维问题&#xff0c;如果直接点击 如何直接点立即清理会跳转企业版购买&#xff0c;1599CNY对普通用…

如何做一个简单的深度集成学习框架

使用同一个框架&#xff0c;独立在一个数据集上面&#xff0c;分别训练多次&#xff0c;每个单独模型训练超参数可以一样&#xff0c;也可以不一样&#xff0c;最后若干个训练好的独立模型在测试集数据上面做最后集中决策。 实例代码如下&#xff1a; class MyEnsemble(nn.Modu…