哈希表之路

哈希表,除了这个名称,还有过另一个名字——散列表!!

散列表主要是链接法,具体不再引述,总而言之,链表里套链表!!!!!!

以下省略10000000000行代码..........

发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火发火

怒发冲冠,仰天长啸:“这怎么理解呀!!”

老师淡淡一笑:“自己想......”


我吃了你!!!!!

其实,没那么复杂,老师讲的是哈希表的升级版的升级版。


嘿嘿,这是一个映射,一个映射。

这个映射要注意,不能确定这是一个满射,还是单射,还是双射。

不过我们希望他是一一对应的,也就是双射。

注意:在操作过程中,p最好设成质数,减少冲突。

探究中,我们发现一个悖论——生日悖论!!!微笑

不过,这是怎么回事呢?疑问

在n个人中,会有两个人出生在同一个月的可能性是n开根!!

一想,不是跟哈希差不多吗,

于是,若要使冲突概率小,p最好开到n平方以上。吐舌头

如果依然不放心,可以试试多重哈希。(也就是存在多个p)。

哈希为了能存放字符串,进制多为31进制。

核心代码(PAS的):

hash[0]:=0; d[0]:=1;

for i:=.........{

hash[i]:=(hash[i-1]*31+ord(s[i])-97+1) mod p;

d[i]:=d[i-1]*31 mod p;}

s[i..j]的哈希值=(hash[j]-hash[i-1]*d[j-i+1] mod p+p) mod p;

再见!微笑微笑微笑微笑微笑微笑

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值