哈希表查找速度為什麽那麽快?快在哪裏了?
阿新 • • 發佈:2017-06-27
浪費 大小 我想 得到 現在 nbsp 看書 一個數 問題
先看數組存儲數據是怎麽樣的。
現在有一個數組,它裏面每個單元存儲的是數據的地址
這叫指針數組吧,假設它有100個單元
我們稱他為p[100]
現在我想把一百個數據(地址)放到裏面
我們想把某個數據放到p的第幾個單元完全是由
我們決定的,可以說想怎麽放就怎麽放
是一種亂放,既然是亂放,那麽查找起來就比較耗時。
哈希表是怎麽存儲數據的呢?
哈希表同樣是一個指針數組。
同樣需要存儲100個數據,需要的就不是100個單元了,因為哈希表要把某個數據存放在某個單元不是隨機的一個過程,而是算出來的,這個算法叫哈希函數
比如要存儲一個數據對
張三 1882356
李四 23456789
王五 58856456
張三經過哈希函數算出來的值是138,那麽哈希表最少需要138個單元,因為張三對應的數據1882356要存儲在指針數組的p[138]的位置上。
李四經過哈希函數算出來的值是500,那麽2356789這個數據就要存放在p[500]這個位置上。
所以你明白了,"數據的地址放在指針數組的哪個單元格是算出來的,是有跡可尋的,並不是想放在哪裏就放在哪裏"
那查找的時候就好查找了,你要查找張三對應的數據,
直接把張三用哈希函數算一下,得到138,哦 張三的數據就在p[138]這個位置上,所以一下就找到了。
哈希表是一個key- value的數據對,p是一個指針數組,用來存放value的地址,那麽key和value的關系是下面這樣的。
p[f(key)]=&value
可以看出哈希表有時候會浪費很大空間的,比如上面張三 李四 王五那個例子 如果按照哈希表存儲要定義一個500個大小的指針數組。怎麽解決這個問題呢?我再看看書。
哈希表查找速度為什麽那麽快?快在哪裏了?