ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

unordered_map和map的差异

2021-07-30 18:33:29  阅读:123  来源: 互联网

标签:map 结点 差异 unordered 哈希 红黑树 排序 节点


内部实现机理:

  • map:红黑树(一种非严格平衡二叉排序树),具有自动排序的功能,红黑树的每一个结点代表着map的一个元素,因此,对于map的增删改查都相当于对于红黑树的操作,因此,使用中序遍历(左中右)可以将元素升序输出。

    二叉排序树指的是左孩子结点的值小于根结点的值,右孩子结点的值大于根结点的值,比如传统的二叉排序树(BST)和平衡二叉树(AVL)

  • unordered_map:哈希表(hashtable),也叫散列表,通过把关键码值映射到Hash表中一个位置来访问记录,查找的时间复杂度可达到O(1),其在海量数据处理中有着广泛应用。

优缺点:

map:

  • 有序性,这是map结构最大的优点,其元素的有序性在很多应用中都会简化很多的操作
  • 红黑树,内部实现一个红黑书使得map的很多操作在logn的时间复杂度下就可以实现,因此效率非常的高
  • 缺点: 空间占用率高,因为map内部实现了红黑树,虽然提高了运行效率,但是因为每一个节点都需要额外保存父节点、孩子节点和红/黑性质,使得每一个节点都占用大量的空间

unordered_map:

  • 优点: 因为内部实现了哈希表,因此其查找速度非常的快
  • 缺点: 哈希表的建立比较耗费时间

标签:map,结点,差异,unordered,哈希,红黑树,排序,节点
来源: https://blog.csdn.net/H2226958871/article/details/119253824

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有