Java 數(shù)據(jù)結(jié)構(gòu)與算法系列精講之哈希算法實現(xiàn)
概述
從今天開始, 小白我將帶大家開啟 Java 數(shù)據(jù)結(jié)構(gòu) & 算法的新篇章.

獲取哈希值
hashCode()方法可以返回一個對象的哈希值. 需要注意的是, 我們需要對值進行裝箱, 才能調(diào)用
hashCode()方法.

例子:
public static void main(String[] args) {
// 小數(shù)
Integer a = 1;
System.out.println(a.hashCode());
// 負數(shù)
Integer b = -1;
System.out.println(b.hashCode());
// 小數(shù)
Double c = 1.23;
System.out.println(c.hashCode());
// 字符串
String d = "Hello World";
System.out.println(d.hashCode());
}
輸出結(jié)果:
1
-1
1158867386
-862545276
哈希沖突
哈希沖突 (Hash Collision) 存在的原因是哈希算法被計算的數(shù)是無限的, 然而計算后的結(jié)果范圍有限. 所以會出現(xiàn)兩個不同的數(shù)據(jù)得到相同的哈希值的情況, 即哈希沖突.

哈希沖突的處理辦法:
- 鏈地址法: 將具有相同的 hash 值的 key 放入到同一個桶中
- 開放地址法: 將具有相同 hash 值的 key 的后一個值向后順移到空位
到此這篇關(guān)于Java 數(shù)據(jù)結(jié)構(gòu)與算法系列精講之哈希算法實現(xiàn)的文章就介紹到這了,更多相關(guān)Java 哈希算法實現(xiàn)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot學(xué)習(xí)之Thymeleaf模板引擎及原理介紹
本文主要介紹一下SpringBoot給我們推薦的Thymeleaf模板引擎,這模板引擎呢,是一個高級語言的模板引擎,他的這個語法更簡單而且功能更強大,對springboot?Thymeleaf模板引擎相關(guān)知識感興趣的朋友一起看看吧2022-02-02
Java8?stream流分組groupingBy的使用方法代碼
對于java8的新特性groupingBy方法,相信有很多人都在工作中用過,這篇文章主要給大家介紹了關(guān)于Java8?stream流分組groupingBy的使用方法,需要的朋友可以參考下2024-01-01
Java?數(shù)據(jù)結(jié)構(gòu)與算法系列精講之?dāng)?shù)組
數(shù)組是有序的元素序列,若將有限個類型相同的變量的集合命名,那么這個名稱為數(shù)組名。組成數(shù)組的各個變量稱為數(shù)組的分量,也稱為數(shù)組的元素,有時也稱為下標(biāo)變量。數(shù)組是在程序設(shè)計中,為了處理方便, 把具有相同類型的若干元素按有序的形式組織起來的一種形式2022-02-02

