0

0

c++中unordered_map怎么用_unordered_map使用方法详解

下次还敢

下次还敢

发布时间:2025-10-11 09:01:01

|

1257人浏览过

|

来源于php中文网

原创

unordered_map是基于哈希表的关联容器,平均O(1)时间复杂度实现查找、插入和删除。需包含头文件,常用操作包括insert、emplace、[]访问、find查找、erase删除及范围遍历,不保证元素顺序,自定义键类型需提供哈希函数或重载==运算符。

c++中unordered_map怎么用_unordered_map使用方法详解

unordered_map 是 C++ STL 中提供的一种基于哈希表实现的关联容器,用于存储键值对(key-value pairs),它的查找、插入和删除操作平均时间复杂度为 O(1),比 map 的 O(log n) 更高效。下面详细介绍 unordered_map 的基本用法和常见操作。

包含头文件与命名空间

使用 unordered_map 前需要包含对应的头文件:

#include
同时建议使用 std 命名空间或加上 std:: 前缀:
using namespace std; // 或显式写 std::unordered_map

定义与初始化

声明一个 unordered_map 的语法如下:

std::unordered_map map_name;

常用示例:
  • unordered_map id_to_name; // 键为整数,值为字符串
  • unordered_mapword_count; // 统计单词出现次数
  • unordered_map> adj_list; // 邻接表建图

支持的初始化方式:

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

  • unordered_map m = {{"apple", 1}, {"banana", 2}};
  • unordered_map m({{1, "one"}, {2, "two"}});

常用操作方法

1. 插入元素

  • m[key] = value; // 若 key 不存在则创建并赋值,存在则覆盖
  • m.insert({key, value}); // 插入键值对,若 key 已存在则不插入
  • m.emplace(key, value); // 原地构造,效率更高,推荐大量插入时使用

2. 访问元素

  • cout apple"]; // 直接通过键访问值,若 key 不存在会自动创建(值初始化)
  • 使用 at() 更安全:m.at("apple"),若 key 不存在会抛出 out_of_range 异常

3. 查找元素

  • auto it = m.find(key); // 返回迭代器,找不到时返回 m.end()
  • if (it != m.end()) cout first second;
  • bool exists = m.count(key); // 返回 0 或 1,适合判断是否存在

4. 删除元素

有道翻译AI助手
有道翻译AI助手

有道翻译提供即时免费的中文、英语、日语、韩语、法语、德语、俄语、西班牙语、葡萄牙语、越南语、印尼语、意大利语、荷兰语、泰语全文翻译、网页翻译、文档翻译、PDF翻

下载
  • m.erase(key); // 按键删除
  • m.erase(iterator); // 删除迭代器指向的元素
  • m.clear(); // 清空所有元素

5. 遍历 unordered_map使用范围 for 循环遍历:

for (const auto& pair : m) {
    cout "
}

或使用迭代器:

for (auto it = m.begin(); it != m.end(); ++it) {
    cout first second
}

其他常用属性与函数

  • m.size(); // 当前元素个数
  • m.empty(); // 判断是否为空,返回 true/false
  • m.max_size(); // 容器可容纳的最大元素数(很少用)
  • m.bucket_count(); // 哈希桶数量
  • m.load_factor(); // 负载因子 = size / bucket_count

注意:unordered_map 不保证元素顺序,遍历时顺序是无序的。如果需要有序,应使用 map。

自定义类型作为键时,需提供 hash 函数或重载 == 运算符,否则编译失败。标准类型如 int、string、double 等已内置支持。

基本上就这些。掌握 insert、find、[]、erase 和遍历就能应对大多数场景。性能高,写算法题和实际开发都很实用。不复杂但容易忽略细节,比如用 [] 访问不存在的 key 会插入默认值,可能影响逻辑判断。

相关专题

更多
string转int
string转int

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

315

2023.08.02

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

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

1465

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

228

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

85

2025.10.17

if什么意思
if什么意思

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

738

2023.08.22

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

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

197

2023.11.20

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

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

523

2023.09.20

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

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

256

2023.08.03

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

5

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.8万人学习

C 教程
C 教程

共75课时 | 4万人学习

C++教程
C++教程

共115课时 | 12.4万人学习

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

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