当前位置: 首页 > article >正文

什么是哈希算法?(大白话+原理+应用,一次讲透)

文章目录一、一句话定义二、用生活例子秒懂对应到代码里三、哈希算法的核心特性面试必背四、为什么 HashSet.contains() 是 O(1)结合哈希原理五、哈希算法的常见应用你日常都在用1. 数据结构HashSet / HashMap你这道题的核心2. 密码存储互联网大厂核心应用3. 文件校验下载/传输必备4. 区块链/比特币六、哈希碰撞是什么怎么解决1. 哈希碰撞的定义2. 常见解决方法Java HashSet 用的就是这个1链地址法Java 8 之前2数组链表红黑树Java 8七、常见的哈希算法有哪些八、回到你的题目哈希算法的作用九、极简总结面试直接背我用最通俗、最不绕弯的方式从「是什么→怎么工作→为什么快→有什么用」给你讲清楚完全贴合你之前的HashSet场景。一、一句话定义哈希算法Hash Algorithm也叫散列算法是一种把任意长度的输入数据通过固定的计算规则转换成固定长度、唯一近似唯一的输出值的算法。输入任意长度的内容比如字符a、字符串abc、文件、图片等输出哈希值Hash Value也叫散列值通常是一串固定长度的数字/字符核心特点输入→输出是单向的、不可逆的且相同输入永远得到相同输出二、用生活例子秒懂你可以把哈希算法理解成一个**「超级智能快递柜分配系统」**快递柜 HashSet底层的哈希表快递 你要存的元素比如字符a、b哈希算法 分配规则根据快递的「收件人手机号」直接算出它应该放在哪个柜子里对应到代码里当你把字符a放进HashSet时HashSet调用哈希算法给a算一个唯一的哈希值比如97就是a的 ASCII 码用哈希值对数组长度取模直接算出a应该放在哈希表的第index个位置下次判断set.contains(a)时直接用同样的算法算出位置去对应柜子里找不用挨个翻所有柜子三、哈希算法的核心特性面试必背特性说明作用确定性相同输入 → 永远得到相同哈希值保证HashSet能精准定位元素单向性只能从输入算哈希值不能从哈希值反推输入密码存储、数据加密的核心雪崩效应输入哪怕只改1个比特哈希值会完全不同防篡改比如文件校验抗碰撞性不同输入 → 尽量得到不同哈希值理论上无法完全避免碰撞保证哈希表性能四、为什么HashSet.contains()是 O(1)结合哈希原理HashSet的底层是哈希表数组链表/红黑树它的contains()流程是对输入元素比如a调用哈希算法算出哈希值用哈希值对数组长度取模得到数组下标直接定位位置去对应下标位置检查是否有该元素整个过程不需要遍历整个集合只做1次哈希计算1次定位查找所以时间复杂度是O(1)平均情况。对比List.contains()List底层是数组没有哈希定位只能从下标0开始挨个遍历比较最坏情况要遍历所有元素所以时间复杂度是O(n)。五、哈希算法的常见应用你日常都在用1. 数据结构HashSet/HashMap你这道题的核心用哈希算法实现 O(1) 时间的增删改查是滑动窗口、缓存、去重等场景的核心数据结构你写的「无重复字符最长子串」就是靠HashSet的 O(1) 查找把暴力 O(n²) 优化成了 O(n)2. 密码存储互联网大厂核心应用网站不会存你的明文密码只会存密码的哈希值登录时把你输入的密码算哈希和数据库里的哈希值比对就算数据库泄露黑客也拿不到你的明文密码3. 文件校验下载/传输必备比如你下载一个系统镜像官网会给一个MD5/SHA256哈希值你下载完后给文件算哈希和官网比对就能确认文件有没有被篡改、有没有下载完整4. 区块链/比特币区块链的每个区块都包含前一个区块的哈希值一旦篡改某个区块哈希值就会变化后面所有区块都会失效保证数据不可篡改六、哈希碰撞是什么怎么解决1. 哈希碰撞的定义理论上输入是无限的哈希值是有限的所以一定会出现「不同输入算出相同哈希值」的情况这就是哈希碰撞。比如两个不同的字符算出了同一个哈希值被分配到了同一个柜子里。2. 常见解决方法JavaHashSet用的就是这个1链地址法Java 8 之前哈希表的每个数组位置都挂一个链表发生碰撞时把元素挂到对应位置的链表上查找时先定位数组位置再遍历链表找元素平均 O(1)最坏 O(n)2数组链表红黑树Java 8当链表长度超过阈值默认8自动把链表转成红黑树把链表的 O(n) 查找优化成红黑树的 O(logn)解决极端碰撞的性能问题七、常见的哈希算法有哪些算法输出长度特点应用场景MD5128位已被破解不推荐用于安全场景文件校验、旧系统SHA-1160位已被破解不推荐用于安全场景Git 版本控制SHA-256256位安全、抗碰撞性强区块链、密码存储、HTTPSCRC3232位计算快、校验效率高网络传输、文件校验八、回到你的题目哈希算法的作用你写的「无重复字符最长子串」用HashSet而不是List本质就是利用哈希算法的 O(1) 定位能力把算法的时间复杂度从 O(n²) 降到了 O(n)这是滑动窗口题型的核心优化思路。九、极简总结面试直接背哈希算法是一种将任意输入转换为固定长度哈希值的算法核心特性是确定性、单向性、抗碰撞性。HashSet基于哈希表实现通过哈希算法直接定位元素位置实现 O(1) 时间的contains()操作而List只能遍历查找时间复杂度 O(n)因此滑动窗口必须用Set/Map而非List。

相关文章:

什么是哈希算法?(大白话+原理+应用,一次讲透)

文章目录一、一句话定义二、用生活例子秒懂对应到代码里:三、哈希算法的核心特性(面试必背)四、为什么 HashSet.contains() 是 O(1)?(结合哈希原理)五、哈希算法的常见应用(你日常都在用&#x…...

【GitHub项目推荐--Godogen:一句话生成完整 Godot 游戏的 AI 流水线】⭐⭐⭐

简介 Godogen​ 是一套基于 Claude Code​ 构建的自动化游戏开发流水线。它不仅仅是一个代码生成器,更是一个全栈的“AI 开发团队”:你只需用自然语言描述游戏创意,它便能自动完成架构设计、美术生成、代码编写、引擎截图、视觉质检的全流程…...

终极Enformer基因表达预测指南:如何在10分钟内快速部署深度学习模型

终极Enformer基因表达预测指南:如何在10分钟内快速部署深度学习模型 【免费下载链接】enformer-pytorch Implementation of Enformer, Deepminds attention network for predicting gene expression, in Pytorch 项目地址: https://gitcode.com/gh_mirrors/en/enf…...

GD32F4xx GPIO实战:用按键控制LED,详解输入输出配置与防抖处理

GD32F4xx GPIO实战:从按键消抖到LED控制的完整设计指南 在嵌入式开发中,GPIO(通用输入输出)是最基础却至关重要的外设模块。对于GD32F4xx系列微控制器而言,掌握GPIO的高效配置不仅关乎功能实现,更直接影响系…...

rust-bert 多语言翻译实战:支持 100+ 语言的智能翻译系统

rust-bert 多语言翻译实战:支持 100 语言的智能翻译系统 【免费下载链接】rust-bert Rust native ready-to-use NLP pipelines and transformer-based models (BERT, DistilBERT, GPT2,...) 项目地址: https://gitcode.com/gh_mirrors/ru/rust-bert rust-ber…...

深入解析CC Switch架构:构建AI开发工具统一管理引擎

深入解析CC Switch架构:构建AI开发工具统一管理引擎 【免费下载链接】cc-switch A cross-platform desktop All-in-One assistant tool for Claude Code, Codex, OpenCode, openclaw & Gemini CLI. 项目地址: https://gitcode.com/GitHub_Trending/cc/cc-swit…...

用快马AI十分钟搞定数据库课程设计原型:学生选课系统从ER图到可运行Demo

今天想和大家分享一个超实用的数据库课程设计经验——如何用InsCode(快马)平台快速搭建学生选课系统原型。作为计算机专业学生,每次做数据库课设最头疼的就是从零开始写代码,但这次我发现了一个超级省时的方法。 ER图设计思路 首先需要明确系统核心实体&…...

Ubuntu纯键盘操作全攻略:从入门到精通(附常用快捷键速查表)

Ubuntu纯键盘操作全指南:释放效率革命的终极手册 在数字工作流中,每一次伸手去摸鼠标都意味着思维的中断和效率的流失。Ubuntu作为最受欢迎的Linux发行版之一,其键盘操作体系之丰富远超多数用户的想象——从简单的窗口切换到底层系统调试&…...

PingFangSC字体工程化:从跨平台渲染挑战到企业级解决方案

PingFangSC字体工程化:从跨平台渲染挑战到企业级解决方案 【免费下载链接】PingFangSC PingFangSC字体包文件、苹果平方字体文件,包含ttf和woff2格式 项目地址: https://gitcode.com/gh_mirrors/pi/PingFangSC 一、问题诊断:揭开字体渲…...

WHUCS—OS—lab实验:从零实现一个用户态定时器

1. 用户态定时器实现原理 在操作系统中,定时器是一个非常重要的基础功能。想象一下你每天早上依赖的闹钟 - 它会在特定时间准时响起,提醒你该起床了。用户态定时器的工作原理与此类似,只不过它是在程序运行时提供定时提醒功能。 xv6作为一个…...

PasteMD效果展示:3秒将ChatGPT对话转换为规范技术报告

PasteMD效果展示:3秒将ChatGPT对话转换为规范技术报告 1. 为什么你需要这个工具 你有没有过这样的经历:在ChatGPT里反复调试出一段完美的技术方案,复制粘贴到Word文档时却变成一团乱码?公式显示成一串LaTeX代码,表格错…...

Windows音频路由终极指南:如何免费实现应用程序级音频设备管理

Windows音频路由终极指南:如何免费实现应用程序级音频设备管理 【免费下载链接】audio-router Routes audio from programs to different audio devices. 项目地址: https://gitcode.com/gh_mirrors/au/audio-router 你是否曾遇到过这样的困扰:在…...

大多数团队不是“用不好 PPO”,而是“用错了 PPO”

更多时候,你会听到的是: “PPO 太复杂了,算了”“调了一轮,模型变怪了”“感觉不如再多搞点 SFT 数据” 于是 PPO 很容易被贴上一个标签: “理论上很强,工程上很坑。” 但这个结论,其实并不公…...

微信小游戏安全漏洞深度剖析:从反编译到协议篡改

1. 微信小游戏安全风险全景图 微信小游戏凭借即点即玩的特性迅速占领市场,但很多开发者对安全防护的重视程度远远不够。我见过太多团队把精力全放在玩法创新上,结果上线三天就被破解的案例。常见的安全威胁主要来自三个方向:客户端篡改、协议…...

信号处理中的数字滤波器设计策略指南:从理论到实际应用

信号处理中的数字滤波器设计策略指南:从理论到实际应用 【免费下载链接】gnuradio GNU Radio – the Free and Open Software Radio Ecosystem 项目地址: https://gitcode.com/gh_mirrors/gn/gnuradio 在现代通信系统和信号处理应用中,数字滤波器…...

GNU Radio滤波器设计中的实时处理优化与性能权衡策略

GNU Radio滤波器设计中的实时处理优化与性能权衡策略 【免费下载链接】gnuradio GNU Radio – the Free and Open Software Radio Ecosystem 项目地址: https://gitcode.com/gh_mirrors/gn/gnuradio 在数字信号处理领域,滤波器设计始终是核心挑战之一&#x…...

TEA算法逆向实战:从特征识别到脚本魔改的CTF通关指南

1. TEA算法特征快速识别指南 第一次在CTF比赛中遇到TEA算法时,我盯着反编译代码看了半小时都没反应过来。直到后来总结出几个关键特征,现在遇到这类题目基本能在30秒内锁定目标。最明显的标志就是那个魔性的delta常量0x9E3779B9(或者它的补码…...

Anaconda镜像源失效?三步解决UnavailableInvalidChannel报错

1. 镜像源失效的典型症状 当你兴冲冲地打开终端准备创建新的Python虚拟环境时,突然看到这段红色报错信息: Collecting package metadata (current_repodata.json): failed UnavailableInvalidChannel: The channel is not accessible or is invalid.chan…...

FPGA新手入门:用Verilog手搓一个交通灯控制器(附完整代码与仿真)

FPGA实战:从零构建智能交通灯控制系统的Verilog全流程指南 引言 第一次接触FPGA开发时,我被硬件描述语言的独特思维方式所吸引。与软件编程不同,Verilog让我们能够直接描述硬件电路的行为。交通灯控制系统作为数字电路设计的经典案例&#xf…...

突破媒体捕获限制:猫抓cat-catch浏览器扩展全方位实战指南

突破媒体捕获限制:猫抓cat-catch浏览器扩展全方位实战指南 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 猫抓cat-catch是一款专注于网…...

LeetCode26. 删除有序数组中的重复项 27. 移除元素 35. 搜索插入位置 数组,双指针 二分查找

给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。考虑 nums 的唯一元素的数量为 k。去重后&#xf…...

别再死记公式了!用TL072运放设计带通滤波器,调出干净正弦波的实战心得与误区盘点

TL072运放带通滤波器实战:从波形失真到纯净正弦波的调试艺术 当你第一次用TL072搭建带通滤波器时,是否也遇到过这样的场景:按照教科书上的公式计算参数,焊接好电路,示波器上却显示着畸形的波形——要么顶部扁平像被削峰…...

3步上手ComfyUI-LTXVideo:让文字和图片动起来的AI视频魔法

3步上手ComfyUI-LTXVideo:让文字和图片动起来的AI视频魔法 【免费下载链接】ComfyUI-LTXVideo LTX-Video Support for ComfyUI 项目地址: https://gitcode.com/GitHub_Trending/co/ComfyUI-LTXVideo 想不想把你的文字描述变成生动的视频?或者让静…...

3大场景×5项优化:ComfyUI视频合成VHS_VideoCombine节点全场景应用指南

3大场景5项优化:ComfyUI视频合成VHS_VideoCombine节点全场景应用指南 【免费下载链接】ComfyUI-VideoHelperSuite Nodes related to video workflows 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-VideoHelperSuite 一、基础认知:视频合…...

基于Docker与CUDA的YOLOv5/v7高效部署实战指南

1. 环境准备:从零搭建CUDADocker开发环境 第一次在Docker里跑YOLOv5时,我盯着满屏的CUDA版本报错差点崩溃。后来才发现,环境配置就像搭积木,底层没摆正,上层再漂亮也会塌。下面分享我验证过的环境搭建方案&#xff0c…...

4个关键阶段:让老旧Mac通过OpenCore Legacy Patcher实现系统兼容性与硬件加速解锁

4个关键阶段:让老旧Mac通过OpenCore Legacy Patcher实现系统兼容性与硬件加速解锁 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 老旧设备升级面…...

mysql技巧(十六):覆盖索引 vs 回表 —— 让查询效率提升 10 倍的核心技巧

📝 本章学习目标本章聚焦数据库性能优化,帮助读者彻底掌握覆盖索引与回表的核心原理。通过本章学习,你将全面理解覆盖索引 vs 回表这一核心主题,并能在实际工作中应用这些技巧,让查询效率提升 10 倍以上。 一、引言&am…...

从GC停顿2.3s到零暂停:Java函数GraalVM Native Image迁移全周期复盘(含12个兼容性雷区)

第一章:从GC停顿2.3s到零暂停:Java函数GraalVM Native Image迁移全周期复盘(含12个兼容性雷区)在高吞吐、低延迟的Serverless函数场景中,一个Spring Boot微服务因频繁Full GC导致单次停顿高达2.3秒,严重违反…...

PaddleNLP:面向产业级应用的大语言模型全流程开发套件技术深度解析

PaddleNLP:面向产业级应用的大语言模型全流程开发套件技术深度解析 【免费下载链接】PaddleNLP PaddleNLP是一款基于飞桨深度学习框架的大语言模型(LLM)开发套件,支持在多种硬件上进行高效的大模型训练、无损压缩以及高性能推理。PaddleNLP 具备简单易用…...

当企业规模增长后,IT管理为什么越来越“失控”?

在企业早期,IT 管理往往是“够用就好”。 一套简单的工单工具、一份资产台账、几个人工流程,就足以支撑日常运转。但当企业规模逐渐扩大,员工数量增长、系统复杂度提升、业务节奏加快时,原本“还能用”的 IT 管理方式,…...