news 2026/6/9 23:19:05

详解哈希表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
详解哈希表

哈希表概念

哈希表是一种基于数组 + 哈希函数实现的数据结构,用于快速存储和查找数据。它的核心思想是:

通过 key 来快速找到对应的 value

查找操作在理想情况下可以达到O(1)的时间复杂度。

哈希表也叫散列表,核心组成部分包括:

  1. 哈希函数 (Hash Function)

    • 将 key 映射成数组的索引 (0 到 N-1)

    • 公式:

      index=hash(key)%table_size
  2. 数组

    • 存放数据的容器,每个索引称为一个

  3. 冲突解决策略

    • 不同 key 可能映射到相同的索引 →哈希冲突

    • 常见策略:

      • 拉链法:每个桶用链表存储所有冲突元素

      • 开放地址法:冲突元素在表内寻找下一个空位置(线性探测、二次探测、双重哈希)

哈希函数设计

哈希函数决定了哈希表性能的好坏。设计原则:

均匀分布:尽量让 key 均匀分布到各个桶

高效:计算要快,避免性能瓶颈

确定性:相同 key 必须映射到相同位置

常见哈希函数:

整型 key:直接取模

int hash(int key) { return key % table_size; }

字符串 key:常用多项式滚动哈希

hash = s[0]*31^(n-1) + s[1]*31^(n-2) + ... + s[n-1] index = hash % table_size;

冲突解决策略详解

拉链法

每个桶存储一个链表或其他数据结构(如平衡树)。

插入时将元素加入链表尾部或头部。

查找时在链表中遍历。

优点:实现简单,删除方便。

缺点:最坏情况退化为链表,查找 O(n)。

开放地址法

所有元素存储在数组中,不用链表。

冲突时通过探测找到下一个空槽。

常用探测策略:

线性探测

index = (hash(key) + i) % table_size
i = 0,1,2,...

二次探测

index = (hash(key) + i^2) % table_size

哈希表操作复杂度

操作理想情况平均情况最坏情况
插入O(1)O(1)O(n)
查找O(1)O(1)O(n)
删除O(1)O(1)O(n)

哈希表的应用场景

字典/映射结构:C++unordered_map、JavaHashMap

去重:用 Set 保存唯一值计数统计:频率统计问题

缓存实现:如 LRU Cache 的快速访问

查找优化:通过 key 快速查找复杂对象

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/4 20:37:46

Atmosphere-stable完全指南:7步打造Switch破解系统最佳体验

Atmosphere-stable完全指南:7步打造Switch破解系统最佳体验 【免费下载链接】Atmosphere-stable 大气层整合包系统稳定版 项目地址: https://gitcode.com/gh_mirrors/at/Atmosphere-stable Atmosphere-stable是Switch破解领域的标杆开源项目,作为…

作者头像 李华
网站建设 2026/5/30 23:57:25

5分钟部署Qwen-Image-2512-ComfyUI,中文生图一键搞定

5分钟部署Qwen-Image-2512-ComfyUI,中文生图一键搞定 你是不是也试过:想用AI生成一张带中文标题的海报,结果模型要么把“科技创新”拼成“科枝创新”,要么文字扭曲变形、边缘发虚,甚至直接漏掉整行字?又或…

作者头像 李华
网站建设 2026/6/4 20:08:36

低成本玩转高端游戏:树莓派HMCL启动器实战指南

低成本玩转高端游戏:树莓派HMCL启动器实战指南 【免费下载链接】HMCL huanghongxun/HMCL: 是一个用于 Minecraft 的命令行启动器,可以用于启动和管理 Minecraft 游戏,支持多种 Minecraft 版本和游戏模式,可以用于开发 Minecraft 插…

作者头像 李华
网站建设 2026/5/22 19:29:50

Z-Image-Turbo社区贡献指南:如何提交PR改进开源项目

Z-Image-Turbo社区贡献指南:如何提交PR改进开源项目 1. 了解Z-Image-Turbo UI界面 Z-Image-Turbo是一个轻量高效、开箱即用的图像生成与编辑工具,其核心价值不仅在于模型本身的能力,更在于它为开发者和用户提供了直观易用的交互界面。这个U…

作者头像 李华
网站建设 2026/6/5 15:26:35

GPEN如何导出ONNX模型?推理格式转换教程

GPEN如何导出ONNX模型?推理格式转换教程 GPEN(GAN Prior Embedding Network)作为当前人像修复与增强领域效果突出的生成式模型,凭借其对人脸结构先验的深度建模能力,在低质人像复原、老照片修复、高清人像生成等任务中…

作者头像 李华
网站建设 2026/6/7 9:24:48

如何让老旧Mac设备重获新生?5步完成系统支持扩展

如何让老旧Mac设备重获新生?5步完成系统支持扩展 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 老旧Mac设备面临官方系统支持终止的问题,导致无法…

作者头像 李华