【哈希表】哈希集合(bitmap)

一. 问题背景

之前我们提到了哈希集合的朴素实现

你要知道哈希表的一个重要思想就是使用空间换时间

他引入了一个用作桶的数组。所以我们可以通过O(1)的时间+哈希函数进行插入和检索

不过这种做法空间的浪费太严重了,注意到我们C++中使用hash来实现的set,是不能存储重复元素的。

在这种背景下,我们使用一个int的空间只是为了存储0和1两个数组

如果我们遇到大数据的情况,空间浪费就不容忽视了。

对于0和1两个数字我们完全可以用1个位来存储,这就是我们的bitmap思想

 

二. bitmap的思想

一个int类型的元素,最多能存储32位的信息。这32位都可以用来存储我们的key

不过这里32位最多也只能存储32个key。为此我们引入了数组。

一个拥有m个元素的数组,最多可以存储m * 32个元素的key

我们可以通过以下两个部分来访问这个元素的键:

  1.  确定这个键在那个范围:a[val / 32]
  2.  确定这个键在那个位上:1 << (val % 32)

这样一来就和我们的朴素实现差不多了 。

 

三. 代码实现

class MyHashSet {
private:
  int a[31255];     // 桶;int有32位,这里每
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值