set和unordered_set的底层
时间: 2023-12-10 09:17:45 浏览: 23
set和unordered_set都是C++ STL(Standard Template Library)中的容器,用于存储一组唯一的元素。
set底层实现是红黑树,是一种自平衡的二叉查找树。它的特点是节点的左右子树高度差不超过1,保证了在最坏情况下,查找、插入和删除操作的时间复杂度都是O(logn)。
unordered_set底层实现是哈希表,是一种以键值对形式存储数据的数据结构。它的特点是在平均情况下,查找、插入和删除操作的时间复杂度都是O(1),但在最坏情况下,时间复杂度可能会退化为O(n)。
因此,set适用于需要有序存储的情况,unordered_set适用于不需要有序存储但需要快速查找的情况。
相关问题
unordered_set和unordered_map底层结构
unordered_set和unordered_map的底层结构是哈希表。哈希表是一种根据关键字值直接进行访问的数据结构,通过把关键字映射到表中的一个位置来实现快速查找。在C++中,unordered_set和unordered_map都是使用哈希表来实现的。
哈希表的实现包括以下几个关键部分:
1. 哈希函数:用于将关键字映射到哈希表中的位置。哈希函数可以根据关键字的类型进行特化,比如整形和字符串类型。
2. 哈希桶:哈希表由一系列桶组成,每个桶可以存储一个或多个元素。哈希函数将关键字映射到具体的桶中。
3. 冲突解决方法:由于不同的关键字可能映射到同一个桶中,需要解决冲突问题。常见的解决方法有链地址法和开放地址法。链地址法使用链表将冲突的元素链接在一起,开放地址法则在冲突时重新计算哈希值,找到下一个空闲的位置。
4. 插入和查找:插入操作将元素插入到哈希表中的合适位置,查找操作根据关键字找到对应的元素。
可以看出,unordered_set和unordered_map在底层结构上非常相似,只是unordered_set存储的是唯一的关键字,而unordered_map存储的是键值对(key,value)。哈希表的特性使得它们在插入和查找操作上具有非常高的效率。 <span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [unordered_map和unordered_set的模拟实现](https://download.csdn.net/download/weixin_38629362/14886751)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *2* *3* [简单了解unordered_set和unordered_map底层](https://blog.csdn.net/weixin_57023347/article/details/120217804)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
unordered_set 和unordered_map的区别
unordered_set和unordered_map是C++标准库中的两个容器类,它们的区别如下:
1. 存储方式:unordered_set是一种无序的集合容器,其中的元素没有特定的顺序,而unordered_map是一种无序的键值对容器,可以根据键来查找对应的值。
2. 元素类型:unordered_set存储唯一的元素,而unordered_map存储键值对,其中键是唯一的。
3. 底层实现:unordered_set和unordered_map都是基于哈希表实现的。unordered_set使用哈希函数将元素映射到桶中,而unordered_map则使用哈希函数将键映射到桶中。
4. 访问元素:在unordered_set中,可以通过迭代器或者范围进行元素的访问。在unordered_map中,可以通过键来访问对应的值。
5. 冲突处理:当多个元素被映射到同一个桶中时,称为冲突。unordered_set和unordered_map都使用链地址法解决冲突,即将冲突的元素链接在同一个桶中。
总的来说,unordered_set适用于需要存储唯一元素的场景,而unordered_map适用于需要存储键值对并且通过键快速查找值的场景。它们在使用时具有不同的特点和用途。