hashMap

博客讨论了HashMap中的哈希装填因子,解释了为何HashMap长度必须为2的幂,以确保哈希分布均匀。文章还提到了解决哈希冲突的方法,包括开放定址法和链地址法,并讨论了哈希表设计大小的选择和动态扩容策略。最后,文章探讨了面试中关于HashMap时间复杂度O(1)的思考。
摘要由CSDN通过智能技术生成

哈希的装填因子

装填因子:a=n/m  其中n 为关键字个数,m为表长。

加载因子是表示Hsah表中元素的填满的程度.若:加载因子越大,填满的元素越多,好处是,空间利用率高了,但:冲突的机会加大了.反之,加载因子越小,填满的元素越少,好处是:冲突的机会减小了,但:空间浪费多了.

冲突的机会越大,则查找的成本越高.反之,查找的成本越小.因而,查找时间就越小.

因此,必须在 "冲突的机会"与"空间利用率"之间寻找一种平衡与折衷. 这种平衡与折衷本质上是数据结构中有名的"时-空"矛盾的平衡与折衷.

为什么HashMap中的&位必须为奇数(Length - 1)
从Key映射到HashMap数组的对应位置,会用到一个Hash函数:

index = Hash(“apple”)

如何实现一个尽量均匀分布的Hash函数呢?我们通过利用Key的HashCode值来做某种运算。 
如何进行位运算呢?有如下的公式(Length是HashMap的长度):

index = HashCode(Key) & (Length - 1)

下面我们以“book”的Key来演示整个过程:

1.计算book的hashcode,结果为十进制的3029737,二进制的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值