哈希表,除了这个名称,还有过另一个名字——散列表!!
散列表主要是链接法,具体不再引述,总而言之,链表里套链表!!!!!!
以下省略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;