例如,按上面例9.4所給的關鍵字序列,用拉鍊法構造散列表如圖9.14所示。
用拉鍊法處理衝突,雖然比開放定址法多佔用一些存儲空間用做鏈接指針,但它可以減少在插入和查找過程中同關鍵字平均比較次數(平均查找長度),這是因爲,在拉鍊法中待比較的結點都是同義詞結點,而在開放定址法中,待比較的結點不僅包含有同義詞結點,而且包含有非同義詞結點,往往非同義詞結點比同義詞結點還要多。
如前面介紹的例9.4中,用線性探測法構造散列表的過程,我們知道,對前5個關鍵字的查找,每一個僅需要比較一次,對關鍵字49和24的查找,則需要比較2次,對關鍵字38的查找則需要比較4次,而對43的查找則需要比較3次。因此,對用線性探測法構造的散列表的平均查找長度爲:
ASL=(1×5+2×2+3×1+4×1)/9 ≈1.78
而用拉鍊法構造的散列表上查找成功的平均查找長度爲:
ASL=(1×5+2×3+3×1)/9≈1.55
顯然,開放定址法處理衝突的的平均查找長度要高於拉鍊法處理衝突的平均查找長度。但它們都比前面介紹的其它查找方法的平均查找長度要短。