【Java 数据结构 & 算法】宁可累死自己, 也要卷死别人 10 哈希实现
【摘要】
【Java 数据结构 & 算法】⚠️宁可累死自己, 也要卷死别人 10⚠️ 哈希实现
概述获取哈希值哈希冲突
概述
从今天开始, 小白我将带大家开启 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());
}
输出结果:
1
-1
1158867386
-862545276
哈希冲突
哈希冲突 (Hash Collision) 存在的原因是哈希算法被计算的数是无限的, 然而计算后的结果范围有限. 所以会出现两个不同的数据得到相同的哈希值的情况, 即哈希冲突.
哈希冲突的处理办法:
- 链地址法: 将具有相同的 hash 值的 key 放入到同一个桶中
- 开放地址法: 将具有相同 hash 值的 key 的后一个值向后顺移到空位
文章来源: iamarookie.blog.csdn.net,作者:我是小白呀,版权归原作者所有,如需转载,请联系作者。
原文链接:iamarookie.blog.csdn.net/article/details/121965661
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
作者其他文章
评论(0)