Java|Java 数据结构与算法系列精讲之哈希算法实现
概述
从今天开始, 小白我将带大家开启 Java 数据结构 & 算法的新篇章.
获取哈希值
hashCode()
方法可以返回一个对象的哈希值. 需要注意的是, 我们需要对值进行装箱, 才能调用
hashCode()
方法.
例子:
public static void main(String[] args) {// 小数Integer a = 1; System.out.println(a.hashCode()); // 负数Integer b = -1; System.out.println(b.hashCode()); // 小数Double c = 1.23; System.out.println(c.hashCode()); // 字符串String d = "Hello World"; System.out.println(d.hashCode()); }
【Java|Java 数据结构与算法系列精讲之哈希算法实现】输出结果:
1哈希冲突 哈希冲突 (Hash Collision) 存在的原因是哈希算法被计算的数是无限的, 然而计算后的结果范围有限. 所以会出现两个不同的数据得到相同的哈希值的情况, 即哈希冲突.
-1
1158867386
-862545276
文章图片
哈希冲突的处理办法:
- 链地址法: 将具有相同的 hash 值的 key 放入到同一个桶中
- 开放地址法: 将具有相同 hash 值的 key 的后一个值向后顺移到空位
推荐阅读
- 一篇文章带你Java多线程入门
- Eclipse+Java+Swing实现斗地主游戏(代码)
- big|中国无卤磷酸酯阻燃剂市场发展态势与投资策略分析报告2022-2028年
- Java|吊打级的福利,BAT上班是种什么样的体验 ?
- java人生|毕业两年月薪36k,人与人的差距比人和狗还大
- 笔记|c笔记
- 数据结构|数据结构——链表一网打尽
- JAVA人生|春招来了,这波神仙打架你要不要参战
- Java基础|彻底搞懂Session和Cookie
- javaWeb|HTTP请求