C++常见的三种哈希结构

当我们想使用哈希法来解决问题的时候,我们一般会选择如下三种数据结构。

  • 数组
  • set (集合)
  • map(映射)

集合

底层实现

是否有序

数值是否可以重复

能否更改数值

查询效率

增删效率

std::set

红黑树

有序

O(\log n)

O(\log n)

std::multiset

红黑树

有序

O(\log n)

O(\log n)

std::unordered_set

哈希表

无序

O(1)

$O(1)

红黑树是一种平衡二叉搜索树,所以key值是有序的,但key不可以修改,改动key值会导致整棵树的错乱,所以只能删除和增加。

当我们要使用集合来解决哈希问题的时候,优先使用unordered_set,因为它的查询和增删效率是最优的,如果需要集合是有序的,那么就用set,如果要求不仅有序还要有重复数据的话,那么就用multiset。

映射

底层实现

是否有序

数值是否可以重复

能否更改数值

查询效率

增删效率

std::map

红黑树

key有序

key不可重复

key不可修改

O(\log n)

O(\log n)

std::multimap

红黑树

key有序

key可重复

key不可修改

O(\log n)

O(\log n)

std::unordered_map

哈希表

key无序

key不可重复

key不可修改

O(1)

O(1)

总结一下,当我们遇到了要快速判断一个元素是否出现集合里的时候,就要考虑哈希法。

但是哈希法也是牺牲了空间换取了时间,因为我们要使用额外的数组,set或者是map来存放数据,才能实现快速的查找。

如果在做面试题目的时候遇到需要判断一个元素是否出现过的场景也应该第一时间想到哈希法!

来自 <代码随想录>

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
哈希表是一种常用的数据结构,用于存储和快速检索数据。在哈希,使用哈希函数来将数据的关键字映射到对应的索引位置。然而,由于数据的范围广、不集以及不同关键字可能计算出相同的哈希地址,会导致哈希冲突的出现。 对于哈希冲突的处理,有多种方法可以选择。其一种常见的方法是使用链地址法,即在哈希表的每个位置上使用一个链表来存储具有相同哈希地址的数据元素。当发生哈希冲突时,新的数据元素可以被插入到对应位置的链表。 另一种方法是开放地址法,它尝试将数据插入到其他空闲的位置,直到找到一个空闲位置或者遍历完所有的位置。开放地址法有多种实现方式,例如线性探测、二次探测和双重哈希等。 还有一种方法是使用再哈希法,即使用不同的哈希函数来解决冲突。如果发生冲突,就使用另一个哈希函数重新计算哈希地址,直到找到一个空闲位置为止。 总之,哈希表是一种高效的数据结构,可以通过哈希函数将数据存储在数组,但是在处理哈希冲突时需要选择合适的解决方法,如链地址法、开放地址法或再哈希法等。这样可以确保在插入和查找数据时都能保持较高的效率。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [【 C++哈希表底层结构剖析](https://blog.csdn.net/bit_zyx/article/details/126864217)[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: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值