数据结构:哈希表

1.哈希表

哈希表(hash table),又称++散列表++ ,它通过建立键 key 与值 value 之间的映射,实现高效的元素查询。具体而言,我们向哈希表中输入一个键 key ,则可以在 O(1) 时间内获取对应的值 value

2.哈希表实现

我们先考虑最简单的情况,仅用一个数组来实现哈希表。在哈希表中,我们将数组中的每个空位称为桶(bucket),每个桶可存储一个键值对。因此,查询操作就是找到 key 对应的桶,并在桶中获取 value

3.哈希冲突与扩容

从本质上看,哈希函数的作用是将所有 key 构成的输入空间映射到数组所有索引构成的输出空间,而输入空间往往远大于输出空间。因此,理论上一定存在"多个输入对应相同输出"的情况。

通常情况下哈希函数的输入空间远大于输出空间,因此理论上哈希冲突是不可避免的。比如,输入空间为全体整数,输出空间为数组容量大小,则必然有多个整数映射至同一桶索引。

哈希冲突会导致查询结果错误,严重影响哈希表的可用性。为了解决该问题,每当遇到哈希冲突时,我们就进行哈希表扩容,直至冲突消失为止。此方法简单粗暴且有效,但效率太低,因为哈希表扩容需要进行大量的数据搬运与哈希值计算。为了提升效率,我们可以采用以下策略。

  1. 改良哈希表数据结构,使得哈希表可以在出现哈希冲突时正常工作。
  2. 仅在必要时,即当哈希冲突比较严重时,才执行扩容操作。

哈希表的结构改良方法主要包括"链式地址"和"开放寻址"。

(1)链式地址

在原始哈希表中,每个桶仅能存储一个键值对。链式地址(separate chaining)将单个元素转换为链表,将键值对作为链表节点,将所有发生冲突的键值对都存储在同一链表中。

相关推荐
DdddJMs__1351 小时前
C语言 | Leetcode题解之第403题青蛙过河
c语言·数据结构·算法
网安詹姆斯1 小时前
网络安全(黑客技术)2024年三个月自学计划
网络·数据结构·python·mysql·安全·web安全·github
无限大.2 小时前
数据结构--图
数据结构
DKPT2 小时前
数据结构之排序的基本概念
java·数据结构·笔记·学习·算法
小周的C语言学习笔记3 小时前
鹏哥C语言40---函数参数与函数调用
c语言·数据结构·算法
粉车绿衣搞笑网工女3 小时前
密码学---easy_hash
算法·密码学·哈希算法
破刺不会编程3 小时前
【C++】透析string类
c语言·开发语言·数据结构·c++
明天吃啥。4 小时前
【数据结构】之排序
数据结构·算法·排序算法
深思慎考4 小时前
数据结构——二叉搜索树
数据结构
尘心cx4 小时前
数据结构-顺序表的应用
数据结构