软件编程
位置:首页>> 软件编程>> java编程>> Java 数据结构与算法系列精讲之哈希算法实现

Java 数据结构与算法系列精讲之哈希算法实现

作者:我是小白呀  发布时间:2022-01-10 23:56:07 

标签:Java,哈希实现,数据结构,算法

概述

从今天开始, 小白我将带大家开启 Java 数据结构 & 算法的新篇章.

Java 数据结构与算法系列精讲之哈希算法实现

获取哈希值

hashCode()方法可以返回一个对象的哈希值. 需要注意的是, 我们需要对值进行装箱, 才能调用

hashCode()方法.

Java 数据结构与算法系列精讲之哈希算法实现

例子:


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) 存在的原因是哈希算法被计算的数是无限的, 然而计算后的结果范围有限. 所以会出现两个不同的数据得到相同的哈希值的情况, 即哈希冲突.

Java 数据结构与算法系列精讲之哈希算法实现

哈希冲突的处理办法:

  • 链地址法: 将具有相同的 hash 值的 key 放入到同一个桶中

  • 开放地址法: 将具有相同 hash 值的 key 的后一个值向后顺移到空位

来源:https://iamarookie.blog.csdn.net/article/details/121965661

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com