unordered_map比map慢?
先说结论:unordered_map不维护键的顺序,因此不能按顺序访问元素,因此如果你需要遍历表时若选用unordered_map就肯定比map慢
1. 数据结构与底层实现
unordered_map:基于 哈希表 实现。- 优点:平均情况下插入、查找和删除操作的时间复杂度为 O(1)O(1)O(1)。
- 缺点:最坏情况下,时间复杂度可能退化为 O(n)O(n)O(n)(当哈希冲突严重时)。
- 无序存储,不能按键排序。
map:基于 红黑树(自平衡二叉搜索树) 实现。- 优点:插入、查找和删除操作的时间复杂度始终为 O(logn)O(\log n)O(logn)。
- 缺点:由于需要维护树的平衡,常数因子较大。
- 按键排序,支持有序遍历。
2. 插入和查找性能
unordered_map优势:在大多数情况下,unordered_map插入和查找的性能优于map,因为其平均时间复杂度为 O(1)O(1)O(1)。map劣势:map的插入和查找性能稍慢,时间复杂度为 O(logn)O(\log n)O(logn)。
例外情况:
- 哈希冲突严重:如果
unordered_map的哈希函数设计不佳或数据分布极端(如大量相同的哈希值),性能可能退化为 O(n)O(n)O(n)。 - 小规模数据:对于数据规模较小的情况,
map的性能可能优于unordered_map,因为红黑树的实现有较少的额外开销。
3. 内存使用
unordered_map缺点:由于哈希表需要额外的存储空间(如空槽和链表节点),unordered_map通常比map占用更多内存。map优势:map是基于树的实现,占用内存相对较少。
4. 顺序访问
unordered_map缺点:unordered_map不维护键的顺序,因此不能按顺序访问元素。map优势:map自动按键的升序(或指定的比较函数)维护元素顺序,支持有序遍历。
5. 插入、删除时对迭代器的影响
unordered_map:当发生哈希表的重哈希(rehash)操作时,会使所有迭代器失效。map:插入和删除元素只会影响相关位置的迭代器,其余迭代器不会失效。
6. 适用场景
| 场景 | 推荐使用容器 | 原因 |
|---|---|---|
| 快速查找/插入操作 | unordered_map |
平均时间复杂度 O(1)O(1)O(1)。 |
| 数据需要按键排序 | map |
支持有序遍历。 |
| 数据规模较小 | map |
红黑树常数因子较小。 |
| 内存有限 | map |
unordered_map 占用内存较大。 |
| 哈希函数性能不佳或数据分布差 | map |
unordered_map 性能退化明显。 |
总结
- 如果需要快速插入、删除和查找操作且不关心顺序,优先选择
unordered_map。 - 如果需要按键排序或者可能遇到哈希冲突问题,选择
map。 - 如果内存占用敏感,选择
map。
unordered_map比map慢?的更多相关文章
- C++11 新特性: unordered_map 与 map 的对比
unordered_map和map类似,都是存储的key-value的值,可以通过key快速索引到value.不同的是unordered_map不会根据key的大小进行排序, 存储时是根据key的ha ...
- hash_map vs unordered_map vs map vs unordered_set
hash_map vs unordered_map 这两个的内部结构都是采用哈希表来实现.unordered_map在C++11的时候被引入标准库了,而hash_map没有,所以建议还是使用unord ...
- (转)unordered_map与map的对比(C++11新特性)
unordered_map和map类似,都是存储的key-value的值,可以通过key快速索引到value.不同的是unordered_map不会根据key的大小进行排序, 存储时是根据key的ha ...
- unordered_map 与 map 的对比(转)
unordered_map和map类似,都是存储的key-value的值,可以通过key快速索引到value.不同的是unordered_map不会根据key的大小进行排序, 存储时是根据key的ha ...
- map 与 unordered_map
两者效率对比: #include <iostream> #include <string> #include <map> #include <unordere ...
- map,hash_map和unordered_map 实现比较
map介绍 Map是STL[1]的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处 ...
- map和unordered_map的差别和使用
map和unordered_map的差别还不知道或者搞不清unordered_map和map是什么的,请见:http://blog.csdn.net/billcyj/article/details/7 ...
- 【转】Map 与 Unordered_map
map和unordered_map的差别和使用 map和unordered_map的差别还不知道或者搞不清unordered_map和map是什么的,请见:http://blog.csdn.net/b ...
- STL——map/unordered_map基础用法
map /multimap map是STL里重要容器之一. 它的特性总结来讲就是:所有元素都会根据元素的键值key自动排序(也可根据自定义的仿函数进行自定义排序),其中的每个元素都是<key, ...
- C++ map与unordered_map
map与unordered_map对比 map unordered_map 红黑树(非严格二叉平衡搜索树)实现 哈希表实现 有序 无序 -- 查找时间复杂度为O(1),非常快 空间消耗较大 空间消耗较 ...
随机推荐
- 谷歌跨域错误解决:request client is not a secure context and the resource is in more-private address
chrome://flags/
- 如何看待:以色列在真主党订购的5000台寻呼机中放了TNT
日常生活等关键物品的生产必须要有国内完全掌握,美国.日本.以色列等国惯用的这种暗杀方法.如果不能在本国国内做到自主可控的产品生产,那么无疑是把自己的脑袋交给敌人来保护,随时都有丢命的可能. 同时,这也 ...
- 关于免费笔记软件Obsidian和免费同步,长文,保存观看
前言 这段可以略过 最早使用的笔记软件(应该说是网页摘录软件)是网文快捕 CyberArticle ,但不停换电脑后当年保存的资料基本都遗失了,那可是我翻阅众多涩涩网站的精华文章. 后来网文快捕推出了 ...
- 2023NOIP A层联测25 T2 游戏
2023NOIP A层联测25 T2 游戏 优秀且新颖的期望题. 思路 分析问题,由于双方都是最优策略,所以可以说学生知道老师会选择那些教室设置概率(概率设置好就不能改变),老师也知道学生会怎样选择教 ...
- 【一步步开发AI运动小程序】十六、AI运动识别中,如何判断人体站位?
[云智AI运动识别小程序插件],可以为您的小程序,赋于人体检测识别.运动检测识别.姿态识别检测AI能力.本地原生识别引擎,无需依赖任何后台或第三方服务,有着识别速度快.体验佳.扩展性强.集成快.成本低 ...
- 洛谷P4913【深基16.例3】二叉树深度题解
很简单的二叉树遍历问题,可以用dfs(深度优先搜索)解决. 看到数据范围,最大不超过 \(10^6\) ,可以不开 long long (但我还是习惯性地开了) 接下来上代码: #include< ...
- Linux系统进程
系统进程 [1].进程基本概述 当我们运行一个程序,那么我们将运行的程序叫进程 PS1:当程序运行为进程后,系统会为该进程分配内存,以及进程运行的身份和权限 PS2:在进程运行的过程中,服务器 ...
- (Python基础教程之十一)Python找到最大的N个(前N个)或最小的N个项目
Python基础教程 在SublimeEditor中配置Python环境 Python代码中添加注释 Python中的变量的使用 Python中的数据类型 Python中的关键字 Python字符串操 ...
- Memcached笔记——(一)安装&常规错误&监控
08年的时候接触过Memcached,当时还对它的客户端产品嗤之以鼻,毕竟手工代码没有各种ORM原生XML配置方便.尽管如此,Memcached现在已经成了服务器架构里不可或缺的一部分! 相关链接: ...
- Shiro 漏洞复现
Shiro 漏洞复现 shiro是什么? ApacheShiro是一个灵活且全面的Java安全框架,它为现代应用程序提供了认证.授权.加密和会话管理等核心安全功能. shiro组件识别 1.在访问及登 ...