键值存储举例。
时间复杂度仅为
O
(
1
)
O(1)
O(1),但是空间空着非常多,效率较低。
散列方法(杂凑法):选取某个函数,依该函数按关键字计算元素的存储位置,并按此存放;
查找时,由同一个函数对给定值
k
k
k计算地址,将
k
k
k与地址单元中元素关键码进行对比,确定查找是否成功。
散列函数(杂凑函数):散列方法中使用的转换函数, H ( k e y ) = k H(key) = k H(key)=k。
散列表(哈希表,杂凑表):按上述思想构造的表。
冲突:不同的关键码映射到同一个散列地址,键不等,地址相等。
同义词:具有相同函数值的多个关键字
构造散列函数考虑的因素
不会产生冲突。
按照余数来进行存储。
在除留余数法的基础上加上了一个增量序列。
di是从1开始进行递增的,1不行就加2加2不行就加3,以此类推。
增量变为伪随机数。
基本思想:相同散列地址的记录链成一单链表m个散列地址就设m个单链表,然后用一个数组将m个单链表的表头指针存储起来,形成一个动态的结构。
这四个求余数后,相同,所以把这些链接在同一个单链表上。