解决hash冲突
什么是hash
任意长度输入经过hash算法转化为固定长度输出(int)
hash算法别名
又称摘要算法、散列算法
特点
不可逆、效率高、冲突少
应用
不可逆→密码、数字签名
hash值计算逻辑→文件完整性验证
基于hash的数据结构
举例hash冲突
Integer xxx = 2112;
// 2112:2112
System.out.println("2112:" + xxx.hashCode());
String Aa = "Aa";
//Aa:2112
System.out.println("Aa:" + Aa.hashCode());
String BB = "BB";
//BB:2112
System.out.println("BB:" + BB.hashCode());
解决hash冲突
1、链地址法
2、开放地址法(向下线性探测或随机探测不冲突的地址)
3、再hash法
4、建立公共溢出区(将哈希表分成两部分,基本表和溢出表,和基本表冲突就填入溢出表)
版权声明:本文所有权归作者! 商业用途转载请联系作者授权! 非商业用途转载,请标明本文链接及出处!
赞成、反驳、不解的小伙伴,欢迎一起交流!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下