0

0

c++ unordered_map怎么用 c++哈希表用法【教程】

冰火之心

冰火之心

发布时间:2026-01-01 17:28:52

|

178人浏览过

|

来源于php中文网

原创

unordered_map 是 C++11 引入的哈希表容器,平均 O(1) 时间复杂度支持增删查改;需包含 头文件,声明如 std::unordered_map m; 支持初始化、迭代器查找、count 判断存在性及范围 for 遍历。

c++ unordered_map怎么用 c++哈希表用法【教程】

unordered_map 是 C++11 引入的标准哈希表容器,底层基于哈希实现,支持平均 O(1) 时间复杂度的插入、查找和删除。它用键(key)快速映射到值(value),不保证元素顺序,适合需要高效随机访问的场景。

怎么声明和初始化 unordered_map

头文件必须包含 #include ,同时需指定 key 和 value 的类型:

  • 空表:`std::unordered_map myMap;`
  • 带初始值:`std::unordered_map<:string int> count{{"a", 1}, {"b", 2}};`
  • 从另一个 map 构造:`std::unordered_map copyMap(originalMap);`

常用操作:增、查、改、删

核心接口简洁直观,和 map 类似但性能更好(无序):

  • 插入/更新:`myMap[key] = value;` 或 `myMap.insert({key, value});`(后者失败时不覆盖)
  • 查找:`auto it = myMap.find(key);` 返回迭代器,查不到时为 `myMap.end()`;也可直接用 `myMap.at(key)`(越界抛异常)或 `myMap[key]`(不存在则默认构造并插入)
  • 判断是否存在:`if (myMap.count(key)) { ... }` —— count 返回 0 或 1
  • 删除:`myMap.erase(key);` 或 `myMap.erase(it);`

遍历和获取大小

因为是无序容器,遍历顺序不确定,但语法和其他容器一致:

MCP官网
MCP官网

Model Context Protocol(模型上下文协议)

下载

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

  • 范围 for 循环:for (const auto& p : myMap) { std::cout "
  • 迭代器方式:for (auto it = myMap.begin(); it != myMap.end(); ++it) { ... }
  • 元素个数:`myMap.size()`;是否为空:`myMap.empty()`

自定义类型作 key 的注意事项

如果要用自定义 struct/class 当 key,必须提供两个东西:

  • 一个 哈希函数对象(重载 operator() 的类,返回 size_t)
  • 一个 相等比较函数(通常重载 operator==
  • 然后把它们作为第 3、4 个模板参数传入,例如:std::unordered_map m;

对 string、int、double 等内置或标准类型,C++ 已内置特化,无需额外处理。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
string转int
string转int

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

312

2023.08.02

if什么意思
if什么意思

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

713

2023.08.22

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

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

193

2023.11.20

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

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

519

2023.09.20

string转int
string转int

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

312

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

522

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

49

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

190

2025.08.29

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

热门下载

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

精品课程

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

共94课时 | 5.7万人学习

C 教程
C 教程

共75课时 | 3.8万人学习

C++教程
C++教程

共115课时 | 10.6万人学习

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

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