当前位置:   article > 正文

C++中unordered_map,unordered_set,map和set的用法和区别

C++中unordered_map,unordered_set,map和set的用法和区别

参考链接:

https://blog.csdn.net/zjajgyy/article/details/65935473


unordered_map和map
unordered_map存储机制是哈希表,,即unordered_map内部元素是无序的。

map是红黑树,map中的元素是按照二叉搜索树存储,进行中序遍历会得到有序遍历

unordered_set和set
unordered_set基于哈希表,是无序的
set实现了红黑树的平衡二叉检索树的数据结构,插入元素时,它会自动调整二叉树的排列,把元素放到适当的位置,以保证每个子树根节点键值大于左子树所有节点的键值,小于右子树所有节点的键值;另外,还得保证根节点左子树的高度与右子树高度相等。

平衡二叉检索树使用中序遍历算法,检索效率高于vector、deque和list等容器,另外使用中序遍历可将键值按照从小到大遍历出来


 unordered_map,unordered_set,map和set可以用平衡二叉搜索树和哈希表的方式实现,由图可以看出,利用的哈希表的方式,时间复杂度最低,但是这种方式有一个缺点在于无序。



 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/452219
推荐阅读
相关标签
  

闽ICP备14008679号