数据结构---散列表(哈希表)

什么是哈希表

1、哈希表(Hash Table):也叫做散列表。是根据关键码值(Key Value)直接进行访问的数据结构。

2、哈希表通过「键 key 」和「映射函数 Hash(key) 」计算出对应的「值 value」,把关键码值映射到表中一个位置来访问记录,以加快查找的速度。这个映射函数叫做「哈希函数(散列函数)」,存放记录的数组叫做「哈希表(散列表)」。

散列表的特点

数组 的最大特点:寻址容易,插入和删除困难

链表 的特点正好相反:寻址困难,而插入和删除操作容易

哈希表 的特点:寻址插入和删除操作都容易

哈希表的关键

哈希表的关键思想是使用哈希函数,将键 key 映射到对应表的某个区块中。我们可以将算法思想分为两个部分:

**向哈希表中插入一个关键码值:**哈希函数决定该关键字的对应值应该存放到表中的哪个区块,并将对应值存放到该区块中。
**在哈希表中搜索一个关键码值:**使用相同的哈希函数从哈希表中查找对应的区块,并在特定的区块搜索该关键字对应的值。

哈希表的结构

哈希表的结构本质是数组+链表

参考文档:数据结构-哈希表_哈希表数据结构-CSDN博客

相关推荐
m0_6294947311 分钟前
LeetCode 热题 100-----17.缺失的第一个正数
数据结构·算法·leetcode
hnjzsyjyj1 小时前
洛谷 P1443:马的遍历 ← BFS
数据结构·bfs
做时间的朋友。2 小时前
精准核酸检测
java·数据结构·算法
如君愿2 小时前
考研复习 Day28 | 习题--计算机网络第四章(网络层 中)、数据结构(树与二叉树 下)
数据结构·计算机网络·考研·课后习题·记录考研
江南十四行2 小时前
排序算法进阶:直接插入排序(简单排序)与希尔排序
数据结构·算法·排序算法
洛水水2 小时前
【Redis入门】一篇详解Redis五大数据结构
数据结构·数据库·redis
CoderCodingNo2 小时前
【CSP】CSP-J 2021真题 | 插入排序 luogu-P7910 (适合GESP四-六级及以上考生练习)
数据结构·算法·排序算法
努力努力再努力wz3 小时前
【MySQL进阶系列】一文打通事务机制:从锁、Undo Log 到 MVCC 与隔离级别
c语言·数据结构·数据库·c++·mysql·算法·github
薇茗3 小时前
【初阶数据结构】 左右逢源的分支诗律 二叉树1
c语言·数据结构·算法
澈2074 小时前
C++ string全面解析:从入门到精通
数据结构·c++·算法