Hash 把...弄乱
与二叉树一样是一种数据结构,为了快速从数组中索引到值
Hash是一个数组,数组里面存放着指针。用%运算(被存数 % 数组总长度)进行存放存放。
表的长度count必须是一个质数,不能被1以上数整除的数,为了将值均匀存入数组里
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | ... |
指针 |
存放数值的过程中,会出现2个%运算结果相同的冲突conflict。此时会有两个解决方式
1链表式,已经存放了数据的下标位置,再添加指针存放新值,后加入的值放在后面,以此类推
2开放式地址,开放地址有3种方式:线性探测法、开平方法、双哈希法
2.1线性探测法,如果下标已存值,那就放到下一个下标,以此类推
2.2如开平方法,如果下标已存值,那就将%运算结果 开平方,存放下标,以此类推
2.3双哈希,如果下标已存值,那就需要用到第二个哈希函数,第二个哈希函数的哈希值必须小于数组的长度,且为质数,计算公式:数组长度-(被存入值 %数组长度),得出结果+第一个哈希结果,存入,如果位置还是有值不为空,就再+第二个哈希结果值,以此类推