数据结构——哈希表

一、基本概念

  1. 哈希:算法思想,将数据根据哈希算法映射成键值,根据键值来写入或是查找数据,以实现查找数据

优势:O(1)时间复杂度

  1. 哈希碰撞(哈希冲突):多个数据通过哈希算法映射成同样的键值,说明产生哈希冲突

  2. 链地址法:数据产生哈希冲突通过在同一键值位置用链表实现多个数据的存储

二、代码实现

1.插入

用静态数组 pHashTable 作为哈希桶,每个桶是一个按 Data 升序排列的链表。

循环初始化:ppTmpNode = &pHashTable[Index];ppTmpNode指向「哈希表的第 Index 个桶项(pHashTable[Index]);但是*ppTmpNode是指向第一个节点的

循环条件:

  • *ppTmpNode != NULL:当前遍历的节点存在,还没到链表末尾。
  • TmpData > (*ppTmpNode)->Data:待插入的数据比当前节点的 Data 大,需要继续往后找。

循环迭代:ppTmpNode = &(*ppTmpNode)->pNext

插入新节点的逻辑:循环结束后,ppTmpNode 指向了插入位置的后继节点指针的地址

  • pNewNode->pNext = *ppTmpNode:新节点的 pNext 指向后继节点(或 NULL)。
  • *ppTmpNode = pNewNode:把新节点挂到 ppTmpNode 指向的指针位置。
  • 无需额外维护前驱节点(因为前驱动点的位置是指向*ppTmpNode的)

2、显示

每次从第i个哈希桶的第一个节点开始打印。

3.查找

根据索引确定在哈希表的哪一个位置,再再从该位置往下遍历链表。

当出现pTmoNode->Data > TmpData时,就可提前结束。

4.销毁

先把第i个哈希表后的链表节点依次消除后,再令pHashTable[i]= NULL;(为了避免出现「野指针」)

注:栈区内存释放:唯一的方式是让变量超出作用域,由系统自动回收,无需手动编码。

  • 全局变量、静态变量(无论局部 / 全局)存在数据区,程序启动时分配、退出时释放,生命周期贯穿整个程序。
  • 局部变量存在栈区,进入作用域时分配、超出作用域时自动释放,仅作用域内有效。
相关推荐
XS0301063 小时前
数据结构-哈夫曼树,红黑树,B树
数据结构·b树
爱吃桃子的ICer4 小时前
m1_pcie
数据结构
贾斯汀玛尔斯5 小时前
每天学一个算法--堆排序(Heap Sort)
数据结构·算法
programhelp_5 小时前
ZipRecruiter CodeSignal OA 2026|最新真题分享 + 速通攻略
数据结构·经验分享·算法·面试
绿豆人5 小时前
go语言的Reflect包
java·开发语言·数据结构
liuyao_xianhui5 小时前
map和set_C++
java·开发语言·数据结构·c++·算法·宽度优先
脱氧核糖核酸__6 小时前
LeetCode热题100——41.缺失的第一个正数(题解+答案+要点)
数据结构·c++·算法·leetcode·哈希算法
努力努力再努力wz6 小时前
【MySQL入门系列】:不只是建表:MySQL 表约束与 DDL 执行机制全解析
android·linux·服务器·数据结构·数据库·c++·mysql
贾斯汀玛尔斯7 小时前
每天学一个算法-- 归并排序(Merge Sort)
数据结构·算法·排序算法
算法鑫探7 小时前
算法中的二分法(二分查找)详解及示例
c语言·数据结构·算法·新人首发