数据结构——哈希表

一、基本概念

  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;(为了避免出现「野指针」)

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

  • 全局变量、静态变量(无论局部 / 全局)存在数据区,程序启动时分配、退出时释放,生命周期贯穿整个程序。
  • 局部变量存在栈区,进入作用域时分配、超出作用域时自动释放,仅作用域内有效。
相关推荐
琢磨先生David2 天前
Day1:基础入门·两数之和(LeetCode 1)
数据结构·算法·leetcode
qq_454245032 天前
基于组件与行为的树状节点系统
数据结构·c#
超级大福宝2 天前
N皇后问题:经典回溯算法的一些分析
数据结构·c++·算法·leetcode
岛雨QA2 天前
常用十种算法「Java数据结构与算法学习笔记13」
数据结构·算法
weiabc2 天前
printf(“%lf“, ys) 和 cout << ys 输出的浮点数格式存在细微差异
数据结构·c++·算法
wefg12 天前
【算法】单调栈和单调队列
数据结构·算法
岛雨QA2 天前
图「Java数据结构与算法学习笔记12」
数据结构·算法
czxyvX2 天前
020-C++之unordered容器
数据结构·c++
岛雨QA2 天前
多路查找树「Java数据结构与算法学习笔记11」
数据结构·算法
AKA__Zas2 天前
初识基本排序
java·数据结构·学习方法·排序