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

网友投稿 269 2022-08-28

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

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

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

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

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

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

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:提取不重复的整数
下一篇:“声音营销”,品牌爆火的另类创意!(声音创意设计)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~