数据结构——哈希表

一、基本概念

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

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

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

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

二、代码实现

1.插入

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

循环初始化:ppTmpNode = &pHashTableIndex;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个哈希表后的链表节点依次消除后,再令pHashTablei= NULL;(为了避免出现「野指针」)

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

  • 全局变量、静态变量(无论局部 / 全局)存在数据区,程序启动时分配、退出时释放,生命周期贯穿整个程序。
  • 局部变量存在栈区,进入作用域时分配、超出作用域时自动释放,仅作用域内有效。
相关推荐
Lsk_Smion10 小时前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode
jidaowansui11 小时前
P11375 [GESP202412 六级] 树上游走
数据结构·算法
一切皆是因缘际会13 小时前
AI智能新时代
数据结构·人工智能·ai·架构
计算机安禾15 小时前
【数据库系统原理】第4篇:关系数据结构的形式化定义:域、笛卡尔积与关系模式
数据结构·数据库·算法
指针战神16 小时前
synchronized简易版Redis版跳表实现(注释干货)
数据结构
handler0117 小时前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
糖果店的幽灵20 小时前
Pandas DataFrame 数据结构详解
数据结构·pandas
Brilliantwxx20 小时前
【C++】 哈希表 unordered_map 与 unordered_set(底层原理 + 线性哈希表代码实现)
开发语言·c++·散列表
起个破名想半天了21 小时前
算法与数据结构之Dijkstra算法
数据结构·dijkstra·单源最短路径·迪杰斯特拉算法
啦啦啦啦啦zzzz21 小时前
数据结构:哈夫曼编码
数据结构·c++·哈夫曼编码