色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

詳解如何使用java實(shí)現(xiàn)Open Addressing

瀏覽:3日期:2022-08-19 13:26:13

你好! 我們這里總共向您提供三種open addression的方法,分別為linear probing、quadratic probing和double hashing。

Linear Probing

Linear probing是計(jì)算機(jī)程序解決散列表沖突時(shí)所采取的一種策略。散列表這種數(shù)據(jù)結(jié)構(gòu)用于保存鍵值對,并且能通過給出的鍵來查找表中對應(yīng)的值。Linear probing這種策略是在1954年由Gene Amdahl, Elaine M. McGraw,和 Arthur Samuel 所發(fā)明,并且最早于1963年由Donald Knuth對其進(jìn)行分析。

假設(shè)A是哈希表的一個(gè)容量N為15的數(shù)組; 將Keys(5、9、12、24、31、40、47、53、62、71)使用linear probing按照順序依次插入到數(shù)組中。

public static void main(String[] args) { int N = 15; int[] A = new int [N]; int[] Keys = {5, 9, 12, 24, 31, 40, 47, 53, 62, 71}; for (int i = 0; i < Keys.length; i++) { int j = 0; int Position = Keys[i] % N; while (A[Position] != 0) { j = j + 1; Position = Keys[i] % N + j; } A[Position] = Keys[i]; } for (int i = 0; i < A.length; i++) { System.out.println(A[i]); } }Quadratic Probing

Quadratic probing是計(jì)算機(jī)程序解決散列表沖突時(shí)所采取的另一種策略,用于解決散列表中的沖突。Quadratic probing通過獲取原始哈希索引并將任意二次多項(xiàng)式的連續(xù)值相加,直到找到一個(gè)空槽來進(jìn)行操作。

假設(shè)A是哈希表的一個(gè)容量N為15的數(shù)組; 將Keys(5、9、12、24、31、40、47、53、62、71)使用quadratic probing按照順序依次插入到數(shù)組中。

public static void main(String[] args) { int N = 15; int[] A = new int [N]; int[] Keys = {5, 9, 12, 24, 31, 40, 47, 53, 62, 71}; for (int i = 0; i < Keys.length; i++) { int j = 0; int Position = Keys[i] % N; while (A[Position] != 0) { j = j + 1; Position = (Keys[i] % N + j*j) % N; } A[Position] = Keys[i]; } for (int i = 0; i < A.length; i++) { System.out.println(A[i]); } }Double Hashing

Double hashing是計(jì)算機(jī)程序解決散列表沖突時(shí)所采取的另一種策略,與散列表中的開放尋址結(jié)合使用,通過使用密鑰的輔助哈希作為沖突發(fā)生時(shí)的偏移來解決哈希沖突。具有open addressing的double hashing是表上的經(jīng)典數(shù)據(jù)結(jié)構(gòu)。

假設(shè)A是哈希表的一個(gè)容量N為15的數(shù)組; 將Keys(5、9、12、24、31、40、47、53、62、71)使用double hashing(我們假設(shè)h’(k)為13 - (k mod 13))按照順序依次插入到數(shù)組中。

public static void main(String[] args) { int N = 15; int[] A = new int [N]; int[] Keys = {5, 9, 12, 24, 31, 40, 47, 53, 62, 71}; for (int i = 0; i < Keys.length; i++) { int j = 0; int Position = (Keys[i] % N + (13 - (Keys[i] % 13)) * j) % N; while (A[Position] != 0) { j = j + 1; Position = (Keys[i] % N + (13 - (Keys[i] % 13)) * j) % N; } A[Position] = Keys[i]; } for (int i = 0; i < A.length; i++) { System.out.println(A[i]); } }

到此這篇關(guān)于詳解如何使用java實(shí)現(xiàn)Open Addressing的文章就介紹到這了,更多相關(guān)java實(shí)現(xiàn)Open Addressing內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 国产高清a毛片在线看 | 在线欧美 | 精品国产免费久久久久久 | 亚洲国产精品综合欧美 | 欧美日韩在线观看一区 | 亚洲人成亚洲精品 | 免费91最新地址永久入口 | 精品在线一区二区 | 一级做a爰片久久毛片鸭王 一级做a爰全过程免费视频毛片 | 国产精品日韩欧美在线第3页 | 色本| 国产精品免费久久 | 日本三级网站在线观看 | 尤物蜜芽福利国产污在线观看 | 久草久视频 | 美女视频永久黄网站在线观看 | 久久精品99毛片免费 | 国产中文字幕视频在线观看 | 日本一区二区三区四区五区 | 国产欧美日韩在线 | 久9青青cao精品视频在线 | 免费看欧美一级片 | 毛片免费观看的视频 | 亚洲欧美精品一区二区 | 一级欧美日韩 | 大陆孕妇孕交视频自拍 | 色拍拍在精品视频69影院在线 | a级国产乱理伦片在线观看99 | 精品一久久香蕉国产二月 | 欧美巨乳在线观看 | 99精品偷自拍 | 日本久久精品 | 国产一二三区视频 | 成年人在线观看免费 | 亚洲欧洲一区二区三区久久 | 一级免费视频 | 欧美三级香港三级日本三级 | 国产中文99视频在线观看 | 免费一级网站免费 | 女人张开腿 让男人桶视频 女人张开腿等男人桶免费视频 | 欧美一级xxx |