Hash哈希

Hash 把...弄乱

与二叉树一样是一种数据结构,为了快速从数组中索引到值

Hash是一个数组,数组里面存放着指针。用%运算(被存数 % 数组总长度)进行存放存放。

表的长度count必须是一个质数,不能被1以上数整除的数,为了将值均匀存入数组里

012345678...
指针

存放数值的过程中,会出现2个%运算结果相同的冲突conflict。此时会有两个解决方式

1链表式,已经存放了数据的下标位置,再添加指针存放新值,后加入的值放在后面,以此类推

2开放式地址,开放地址有3种方式:线性探测法、开平方法、双哈希法

2.1线性探测法,如果下标已存值,那就放到下一个下标,以此类推

2.2如开平方法,如果下标已存值,那就将%运算结果 开平方,存放下标,以此类推

2.3双哈希,如果下标已存值,那就需要用到第二个哈希函数,第二个哈希函数的哈希值必须小于数组的长度,且为质数,计算公式:数组长度-(被存入值 %数组长度),得出结果+第一个哈希结果,存入,如果位置还是有值不为空,就再+第二个哈希结果值,以此类推

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值