首页 > 后端开发 > C++ > 正文

c++怎么使用unordered_map_c++中unordered_map的用法与示例解析

下次还敢
发布: 2025-10-31 15:42:02
原创
337人浏览过
unordered_map是基于哈希表的C++关联容器,提供O(1)平均时间复杂度的查找、插入和删除操作,适用于无需排序的快速访问场景。

c++怎么使用unordered_map_c++中unordered_map的用法与示例解析

unordered_map 是 C++ STL 中提供的关联容器,用于存储键值对(key-value pairs),其底层基于哈希表实现,查找、插入和删除操作的平均时间复杂度为 O(1)。相比 map(基于红黑树,有序),unordered_map 无序但访问更快,适合需要快速查找的场景。

包含头文件与命名空间

使用 unordered_map 需要包含头文件 <unordered_map>,并使用 std 命名空间:

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

基本定义与初始化

声明一个 unordered_map 的格式为:
unordered_map<Key_Type, Value_Type> map_name;

常见用法示例:

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

unordered_map<string, int> ageMap; // 键为字符串,值为整数

支持的初始化方式:

芦笋演示
芦笋演示

一键出成片的录屏演示软件,专为制作产品演示、教学课程和使用教程而设计。

芦笋演示34
查看详情 芦笋演示
  • 空初始化:直接定义后插入数据
  • 列表初始化:unordered_map<string, int> ages = {{"Alice", 25}, {"Bob", 30}};

常用操作方法

以下是一些核心操作及对应函数:

  • 插入元素
    • ageMap["Charlie"] = 35; // 使用下标插入或更新
    • ageMap.insert({"David", 40}); // insert 方法插入 pair
    • ageMap.emplace("Eve", 28); // 原地构造,效率更高
  • 查找元素
    • auto it = ageMap.find("Alice"); // 返回迭代器,找不到返回 end()
    • 判断是否存在:if (ageMap.count("Bob")) { /* 存在 */ }
  • 访问元素
    • cout << ageMap["Alice"]; // 直接通过键访问值(若键不存在会自动创建)
    • 更安全的方式是先 find 再访问,避免意外插入默认值
  • 删除元素
    • ageMap.erase("Bob"); // 按键删除
    • ageMap.erase(it); // 按迭代器删除
  • 遍历所有元素 for (const auto& pair : ageMap) {
      cout << pair.first << ": " << pair.second << endl;
    }
  • 获取大小与清空
    • ageMap.size(); // 元素个数
    • ageMap.empty(); // 是否为空
    • ageMap.clear(); // 清空所有元素

完整示例代码

下面是一个完整的小程序演示 unordered_map 的典型用法:

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

int main() {
  unordered_map<string, int> studentAges = {
    {"Alice", 20},
    {"Bob", 22},
    {"Charlie", 19}
  };

  // 插入新元素
  studentAges["David"] = 21;

  // 查找并输出 Bob 的年龄
  auto it = studentAges.find("Bob");
  if (it != studentAges.end()) {
    cout << "Bob's age: " << it->second << endl;
  }

  // 遍历输出所有学生信息
  for (const auto& s : studentAges) {
    cout << s.first << " - " << s.second << " years old" << endl;
  }

  return 0;
}

注意事项

  • 键类型必须支持哈希函数。C++ 内置类型(如 int、string)已提供 hash 实现,自定义类型需重载 hash 函数或提供仿函数。
  • 不保证元素顺序,遍历时顺序可能每次不同。
  • 使用下标访问不存在的键会自动插入该键并用默认值初始化(如 int 为 0),需注意逻辑错误。
  • 多线程环境下需自行加锁保护,unordered_map 本身非线程安全。

基本上就这些。掌握 unordered_map 能显著提升查找效率,是算法题和工程开发中的常用工具

以上就是c++++怎么使用unordered_map_c++中unordered_map的用法与示例解析的详细内容,更多请关注php中文网其它相关文章!

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

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

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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