程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> 淺談哈希表存儲效率普通不超越50%的緣由

淺談哈希表存儲效率普通不超越50%的緣由

編輯:關於C++

淺談哈希表存儲效率普通不超越50%的緣由。本站提示廣大學習愛好者:(淺談哈希表存儲效率普通不超越50%的緣由)文章只能為提供參考,不一定能成為您想要的結果。以下是淺談哈希表存儲效率普通不超越50%的緣由正文


本文次要是講"哈希表的存儲效率普通不超越50%"的緣由。

Hash Table 常用於頻繁停止 key/value 形式的查找中。(查找形式,如婚配查找)

哈希表最大的優點在於查找速度快,但存儲時能夠發作collision(抵觸)。

哈希表大多運用open addressing來處理collision,此時search的時間復雜度計算公式為:

1/( 1 - n/m )

其中,n與m辨別表示存儲的記載數與哈希表的長度,即裝填因子( load factor )

故,若哈希表半滿,即 n/m >= 1/2,則每次的search次數能夠會 >= 2

因而,為了保證Hash Table在 key/value 查找形式中的優勢,普通,其存儲效率不會超越50%。

以上就是為大家帶來的淺談哈希表存儲效率普通不超越50%的緣由全部內容了,希望大家多多支持~

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved