常用两种方法:链表法和开放寻址法
1.链表法
当出现hash冲突时,会将元素插入对应数组下的链表中(或红黑树),链表插入速度快。在插入或删除的时候,查找对应的数据下的链表,然后查找链表中元素。
2.开发寻址法
当出现hash冲突时,重新探测一个新的空闲位置,将元素插入。
线性探测法:
散列表中插入元素时,如果某个数据经过散列函数散列之后,存储位置已经被占用了,那么我们就从当前位置开始,依次往后遍历,直到找到空余的位置插入为止(插入第一个空余的位置,方便查找)
在查找元素时,先将要查找元素键值通过散列函数变成散列值,然后与下标为散列值的元素比较,若相等,则说明这是我们要找的元素;若不相等,则顺序往后遍历查找,如果遍历到数组中的空余位置还是没有找到,说明要查找的元素不在散列表中
删除时需要特殊标记元素为删除状态,不然当查询元素时,遇见为空的位置就停止查询,默认无法查询到。
线性探测法的缺点:当插入的数据越来越多时,散列冲突发生的可能性会越来越大,空余位置会越来越少,线性探测的时间会越来越长,最坏时间复杂度为O(n)。