数据结构-哈希表(C语言)

哈希表的概念

哈希表就是:

"将记录的存储位置与它的关键字之间建立一个对应关系,使每个关键字和一个唯一的存储位置对

应。"

哈希表又称:"散列法 "、"杂凑法 "、"关键字:地址法"。

哈希表思想

基本思想是在关键字和存储位置之间建立一个哈希函数hash,使每一个存储位置和关键字对应

通常关键字的集合很大,因此经过哈希函数的变换后,可能会将不同的关键字映射到同一个地址

上。这种现象称作:"冲突 ",具有相同函数值的关键字称作:"同义词"。

哈希表属性

哈希函数的值域是可以使用的地址空间,称作基本区域

基本区域的长度是哈希表的长度

同义词可以存放在基本区域中未占用的单元,也可以放在另外开辟的地方。(溢出区

哈希函数的构造

哈希函数的构造一般有下面几种方法:

1.直接定址法

hash(key) = key或hash(key) = a * key + b

直接定址法的构造有点像Python里面的字典。

优点:不会产生冲突

缺点:空间效率不高

2.取余法

hash(key) = key % p

p < m,m是哈希表长。

优点:计算简单,适用范围大

缺点:需要选择一个合适的p,p的选择很困难

一般来说,p是不大于m的最大素数:

3.平方取中法

先计算关键字的平方,然后取平方后数的中间几位作为地址。

key = 2587

key ** 2 = 6692569

若取三位,则hash(2587) = 925。

处理冲突的方法:

1.开放定址法

当发生冲突时,在冲突位置的前后寻找可以存放记录的空闲单元。

当用此法时,需要预先设置一个探测序列d,沿着序列d寻找空闲单元。

数学描述公式为:

H = (hash(key) + d) % m

其中探测序列d有下面三种取法:

1.d = 1,2,3,4,.....,n

2.d =

3.d = 随机数列

用的最多的是1和2

但是使用1的时候,会导致原本不冲突的非同义词也会产生冲突,这种现象叫作:"堆积"(聚

集)。

因此减少堆积可以使用2,但是2并不能保证可以全部使用表中空闲单元,容易造成浪费。

2.拉链法

将具有相同哈希地址的记录连接成一个单链表,然后用一个数组将n个单链表头指针存储起来。

3.再哈希法

当发生冲突时,再用另一个哈希函数计算地址。

4.溢出区法

建立一个额外的公共溢出区,用来存储冲突的记录

相关推荐
ID_180079054732 小时前
小红书笔记详情API接口基础解析:数据结构与调用方式
数据结构·数据库·笔记
iuu_star8 小时前
C语言数据结构-顺序查找、折半查找
c语言·数据结构·算法
漫随流水9 小时前
leetcode算法(515.在每个树行中找最大值)
数据结构·算法·leetcode·二叉树
一起努力啊~14 小时前
算法刷题--长度最小的子数组
开发语言·数据结构·算法·leetcode
小北方城市网14 小时前
第1课:架构设计核心认知|从0建立架构思维(架构系列入门课)
大数据·网络·数据结构·python·架构·数据库架构
好易学·数据结构14 小时前
可视化图解算法77:零钱兑换(兑换零钱)
数据结构·算法·leetcode·动态规划·力扣·牛客网
独自破碎E14 小时前
【归并】单链表的排序
数据结构·链表
L_090714 小时前
【C++】高阶数据结构 -- 平衡二叉树(AVLTree)
数据结构·c++
冰冰菜的扣jio14 小时前
Redis基础数据结构
数据结构·数据库·redis
Qhumaing15 小时前
C++学习:【PTA】数据结构 7-2 实验6-2(图-邻接表)
数据结构·c++·学习