解决哈希冲突的几种方法

本文介绍了哈希冲突的概念,强调其在哈希表中可能导致数据无法存储的问题。文章详细阐述了三种常见的解决哈希冲突的方法:开放地址法,包括线性探测、二次探测和随机探测;二次哈希法,通过额外的哈希函数避免冲突;以及链地址法,通过链表存储相同哈希值的元素。链地址法是目前最常用的方法,但需要额外空间且查找效率较低。
摘要由CSDN通过智能技术生成

Hash冲突的概念

哈希算法 的目的就是将一串很大的数据根据一定的规则转换为较小的数据。
把任意长度的二进制值串映射为固定长度的二进制值串,这个映射的规则就是哈希算法,而通过原始数据映射之后得到的二进制值串就是哈希值
在这个转换过程中,总会出现两个不同的数据在经过哈希算法的计算后生成了相同的哈希值。这就是哈希冲突
哈希冲突带来的影响:
在哈希表中,两个不同数据的哈希值相同,那么不论这两个数据中任意一个先存放到指定位置之后,第二个数据都没有地方可以存放了。所以设计哈希算法的时候一定要注意哈希冲突问题!

哈希算法满足的几点要求:

  1. 从哈希值不能反向推导出原始数据(所以哈希算法也叫单向哈希算法);
  2. 对输入数据非常敏感,哪怕原始数据只修改了一个 Bit,最后得到的哈希值也大不相同;
  3. 散列冲突的概率要很小,对于不同的原始数据,哈希值相同的概率非常小;
  4. 哈希算法的执行效率要尽量高效,针对较长的文本,也能快速地计算出哈希值

常见的三种解决哈希冲突的方法

1. 开放地址法

为产生冲突的地址Hash(key)求得一个地址序列:

H0,H1,H2,...,Hn        1  <= n <= m - 1 其中m为表的大小

H0 = H(
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值