unordered_map和unordered_set的底层区别
时间: 2023-10-21 22:27:03 浏览: 118
unordered_map和unordered_set的底层实现都是使用哈希表(hash table),但它们的用途和数据结构略有不同。
unordered_map是一种关联容器,它存储键值对(key-value pairs),并根据键(key)来快速访问值(value)。底层使用哈希表来实现,通过计算键的哈希值并将其映射到哈希表中的桶(bucket),从而实现常数时间(O(1))的查找、插入和删除操作。
unordered_set是一种集合容器,它存储唯一的元素,并且不按任何特定顺序进行排序。底层使用哈希表来实现,通过计算元素的哈希值并将其映射到哈希表中的桶,从而实现常数时间(O(1))的查找、插入和删除操作。
因此,它们的底层实现非常相似,都是基于哈希表的。区别在于unordered_map存储键值对,而unordered_set只存储唯一的元素。
相关问题
unordered_set和unordered_map与set和map的区别
unordered_set和unordered_map是C++标准库中的容器,而set和map也是C++标准库中的容器。它们之间的区别主要有以下几点:
1. 实现方式:unordered_set和unordered_map使用哈希表实现,而set和map使用红黑树实现。哈希表的插入、查找和删除操作的平均时间复杂度为O(1),而红黑树的平均时间复杂度为O(log n)。
2. 元素顺序:unordered_set和unordered_map中的元素是无序的,而set和map中的元素是按照键值进行排序的。如果需要按照特定顺序访问元素,可以使用set和map;如果不需要关心元素的顺序,可以使用unordered_set和unordered_map。
3. 键值唯一性:set和unordered_set中的键值是唯一的,即每个键只能出现一次;而map和unordered_map中的键值是唯一的,但值可以重复。
4. 内存占用:由于使用了哈希表,unordered_set和unordered_map通常会占用更多的内存空间,而set和map通常会占用较少的内存空间。
5. 迭代器稳定性:在进行插入和删除操作后,set和map中的迭代器仍然有效,而unordered_set和unordered_map中的迭代器可能会失效。
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 ]
阅读全文