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

什么是哈希表

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

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

散列表的特点

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

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

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

哈希表的关键

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

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

哈希表的结构

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

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

相关推荐
海清河晏1111 分钟前
字符串匹配:BF算法与KMP算法
数据结构·算法·visual studio
QiLinkOS36 分钟前
QiLink 技术委员会选举实施细则
c语言·数据结构·c++·单片机·嵌入式硬件·算法·开源
无忧.芙桃42 分钟前
数据结构之顺序表的实现
数据结构
我叫张小白。1 小时前
Redis的缓存雪崩、击穿、穿透和解决方案
数据结构·redis·fastapi·缓存穿透·缓存击穿·雪崩·热点key问题
QiLinkOS1 小时前
发明人与专利价值共生逻辑
c语言·数据结构·c++·人工智能·单片机·嵌入式硬件·算法
南境十里·墨染春水2 小时前
数据结构 ——BST 树
数据结构
江屿风2 小时前
C++图的基本概念流食般投喂-竞赛编
开发语言·数据结构·c++·笔记·算法·图论
Byte不洛2 小时前
哈希表原理 + 冲突解决 + C++实现
数据结构·c++·算法·哈希算法·散列表
_日拱一卒11 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
2401_8685347813 小时前
【无标题】
数据结构·r语言