首頁  >  文章  >  Java  >  負載因子和重新哈希

負載因子和重新哈希

王林
王林原創
2024-07-28 07:12:52758瀏覽

Load Factor and Rehashing

負載因子衡量雜湊表的填充程度。如果超過載入因子,則增加雜湊表大小並將條目重新載入到新的更大的雜湊表中。這稱為重新哈希。負載因子 l (lambda) 衡量雜湊表的填充程度。是
數量的比例 元素與雜湊表的大小,即 l = n / N,其中 n 表示元素的數量,N 表示雜湊表中位置的數量。

請注意,如果雜湊表為空,則 l 為零。對於開放尋址方案,l 介於 01 之間;如果雜湊表已滿,則 l 為 1。對於單獨的連結方案,l 可以是任何值。

隨著 l 的增加,碰撞的機率也會增加。研究表明,對於開放尋址方案,您應將負載因子保持在 0.5 以下,對於單獨連結方案,應將負載因子維持在 0.9 以下。

將負載因子保持在一定閾值以下對於雜湊的效能非常重要。在 Java API 中 java.util.HashMap 類別的實作中,使用閾值 0.75。每當負載因子超過閾值時,您就需要增加哈希表的大小,並將映射中的所有條目重新哈希到一個新的更大的哈希表中。請注意,您需要更改雜湊函數,因為哈希表大小已更改。為了減少重新散列的可能性,因為它的成本很高,您應該至少將散列表大小增加一倍。即使定期重新散列,散列也是映射的有效實作。

以上是負載因子和重新哈希的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn