Hash函数和Hash冲突

一、简介

  将任意长度的数值以某个映射规则映射为固定长度的数值,这个过程称为Hash,而这个映射规则被称为Hash函数,而对这个key、value进行存储的数据结构被称为Hash表。
  由于通过key的hash映射直接得到了内存地址,所以hash查找的时间复杂度是O(1),但也因此开辟了hash表的内存空间,属于用空间换取时间的典型例子。
  如果不同的key经过hash函数的映射到了同一个位置,这个情况就是hash冲突了,虽然有了冲突就要解决,但是选取一个好的hash函数,使得映射的位置分布均匀也是很重要的。

二、解决Hash冲突

举例:
arr=[4,6,9,14]
hash函数(一般为取模函数,模选取某个质数) h = n%5
在这里插入图片描述
很明显4与9,14冲突了。

1.开放定址法

这个地址冲突了,给它换个地址。

①线性探测再散列

这个位置冲突了,直接向后挪动一位,如果后面一位也冲突了,继续向后挪动。
在这里插入图片描述

②二次探测再散列

这个位置冲突了,第一次向后挪动一位,第二次挪动4位,第三次挪动9位,第n次移动第n^2位。
在这里插入图片描述

③伪随机数再散列

这个位置冲突了,每次移动的数是个随机数。

2.rehash

构造多个hash函数,对于第一次hash冲突的值再进行hash计算。
还是上面的例子,对于冲突的4,9,14还可以构造一个hash函数 h1=n%7
在这里插入图片描述

3.链表法

即冲突的元素不再往左右挪动了,而是以链表的形式存在。(HashMap就是采用这种方式,具体方式以后再写博客记录)
在这里插入图片描述

4.建立公共溢出区

即将hash表拆分为两个表,基本表和溢出表,溢出的值全部放在溢出表中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Selenium399

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值