0

0

c++怎么使用unordered_map_c++ unordered_map用法与示例教程

下次还敢

下次还敢

发布时间:2025-10-19 22:05:01

|

604人浏览过

|

来源于php中文网

原创

unordered_map是基于哈希表的键值对容器,提供平均O(1)查找、插入和删除操作,元素无序。包含头文件,定义为unordered_map name;支持[]、insert、emplace插入,[]访问或at()方法,find和count查找,erase删除,范围for循环遍历;键需支持hash和==比较,自定义类型需提供hash函数;性能依赖哈希质量,无序场景适用,有序需求应选map。

c++怎么使用unordered_map_c++ unordered_map用法与示例教程

在C++中,unordered_map 是一个基于哈希表实现的关联容器,用于存储键值对(key-value pairs),它提供了平均情况下常数时间的查找、插入和删除操作。与 map 不同,unordered_map 中的元素是无序的,不按键排序。

包含头文件与基本定义

使用 unordered_map 需要包含头文件

#include iostream>
#include
using namespace std;

定义方式如下:

unordered_map map_name;

例如,创建一个以字符串为键、整数为值的哈希表:

立即学习C++免费学习笔记(深入)”;

unordered_map ageMap;

常用操作与示例

1. 插入元素

有多种方式可以插入键值对:

  • 使用 insert() 方法
  • 使用下标操作符 []
  • 使用 emplace() 原地构造
ageMap["Alice"] = 25;
ageMap.insert(make_pair("Bob", 30));
ageMap.emplace("Charlie", 35);

2. 访问元素

通过键访问值,使用 operator[]at() 方法:

cout cout

注意:如果键不存在,[] 会自动插入该键并赋予默认值,而 at() 会抛出 out_of_range 异常。

Rationale
Rationale

Rationale 是一款可帮助企业主、经理和个人做出艰难的决定的AI工具

下载

3. 查找元素

使用 find() 判断键是否存在:

if (ageMap.find("Alice") != ageMap.end()) {
    cout }

也可以用 count(),对于 unordered_map 来说返回值是 0 或 1:

if (ageMap.count("Bob")) {
    cout }

4. 删除元素

使用 erase() 删除指定键:

ageMap.erase("Charlie"); // 删除键为 "Charlie" 的元素

5. 遍历 unordered_map

使用范围 for 循环遍历所有元素:

for (const auto& pair : ageMap) {
    cout }

输出可能是无序的,因为底层是哈希表。

完整示例代码

#include stream>
#include
using namespace std;

int main() {
    unordered_map scores;

    scores["Tom"] = 85;
    scores["Jerry"] = 92;
    scores.insert({"Spike", 78});

    if (scores.find("Tom") != scores.end()) {
        cout     }

    cout     for (const auto& s : scores) {
        cout     }

    return 0;
}

注意事项

• 键类型必须支持 hash 函数== 比较操作。标准类型如 int、string 已经支持。
• 自定义类型作为键时,需要提供 hash 特化或自定义 hash 函数。
• unordered_map 的性能依赖于哈希函数的质量,冲突多会影响效率。
• 如果需要有序遍历,请使用 map 而不是 unordered_map。

基本上就这些,掌握 insert、find、[]、erase 和遍历就能应对大多数场景了。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

710

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.11.20

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

518

2023.09.20

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

247

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

205

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1434

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

609

2023.11.24

JavaScript 性能优化与前端调优
JavaScript 性能优化与前端调优

本专题系统讲解 JavaScript 性能优化的核心技术,涵盖页面加载优化、异步编程、内存管理、事件代理、代码分割、懒加载、浏览器缓存机制等。通过多个实际项目示例,帮助开发者掌握 如何通过前端调优提升网站性能,减少加载时间,提高用户体验与页面响应速度。

3

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号