第三章 3.1 哈希表_第1頁
第三章 3.1 哈希表_第2頁
第三章 3.1 哈希表_第3頁
第三章 3.1 哈希表_第4頁
第三章 3.1 哈希表_第5頁
已閱讀5頁,還剩13頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

第三章查找與排序技術(shù)什么是哈希表設(shè)表的長度為n,如果存在一個函數(shù)i=i(k),對于表中的任意一個元素的關(guān)鍵字k,滿足則稱此表為Hash表。其中函數(shù)i=i(k)稱為關(guān)鍵字k的Hash碼。Hash表技術(shù)的關(guān)鍵是要處理好表中元素的沖突問題,它主要包括以下兩方面的工作:①構(gòu)造合適的Hash碼,以便盡量減少表中元素沖突的次數(shù),即Hash碼的均勻性要比較好。②當(dāng)表中元素發(fā)生沖突時,要進(jìn)行適當(dāng)?shù)奶幚?。Hash碼的構(gòu)造Hash表技術(shù)的主要目標(biāo)是提高查找效率,即縮短查表的時間。⑴截斷法。是指選取與關(guān)鍵字對應(yīng)的數(shù)字串中的一段(一般選取低位數(shù))作為該關(guān)鍵字的Hash碼。⑵分段疊加法。將關(guān)鍵字的編碼串分割成若干段,然后把他們疊加后再進(jìn)行截段。⑶除法。將關(guān)鍵字的編碼除以表的長度,最后所得的余數(shù)作為Hash碼,即取Hash碼為i=mod(k,n)(當(dāng)mod(k,n)0時,取i=n)本方法構(gòu)造的Hash碼,其均勻性比較好,但是以一次除法為代價,在除法較快的機(jī)器上可以采用。⑷乘法。將關(guān)鍵字編碼與一個常數(shù)相乘后,再除以表長度n,取其余數(shù)作為Hash碼線性Hash表是一種最簡單的Hash表。⑴設(shè)線性表的長度為n,則將關(guān)鍵字k及有關(guān)信息填入線性Hash表的步驟如下:①計算關(guān)鍵字k的Hash碼i=i(k).②檢查表中第i項(xiàng)的內(nèi)容:若第i項(xiàng)為空,則將關(guān)鍵字k及有關(guān)信息填入該項(xiàng);若第i項(xiàng)不空,則令i=mod(i+1,n),轉(zhuǎn)②繼續(xù)檢查。1.線性hash表⑵線性Hash表的取出①計算關(guān)鍵字k的Hash碼i=i(k).②檢查表中第i項(xiàng)的內(nèi)容:若第i項(xiàng)登記著關(guān)鍵字k,則取出該項(xiàng)元素即可;若第i項(xiàng)為空,則表示在Hash表中沒有該關(guān)鍵字的信息;若第i項(xiàng)不空,且登記的不是關(guān)鍵字k,則令i=mod(i+1,n),轉(zhuǎn)②繼續(xù)檢查。線性表的優(yōu)缺點(diǎn):優(yōu)點(diǎn):簡單缺點(diǎn):①在線性Hash表填入的過程中,當(dāng)發(fā)生沖突時,首先考慮的是下一項(xiàng),因此,當(dāng)Hash碼的沖突較多時,在線性Hash表中會存在“堆聚”現(xiàn)象,即許多關(guān)鍵字被連續(xù)登記在一起,從而會降低查找效率。②在線性Hash表的填入過程中,處理沖突時會帶來新的沖突,即線性Hash表的填入方法是不顧后效的。2.隨機(jī)Hash表當(dāng)Hash表的長度n設(shè)計成n=2m時,還可以定義另外一種Hash表——隨機(jī)Hash表。隨機(jī)Hash表與線性Hash表的不同之處在于:一旦發(fā)生元素沖突時,表項(xiàng)序號i的改變不是采用加1取模的方法,而是用某種偽隨機(jī)數(shù)來改變。⑴隨機(jī)Hash表的填入:①計算關(guān)鍵字k的Hash碼i0=i(k),且令i=i0.②偽隨機(jī)數(shù)序列初始化,令j=1(將隨機(jī)數(shù)指針指向偽隨機(jī)數(shù)序列的第1個隨機(jī)數(shù))③檢查表中第i項(xiàng)的內(nèi)容:若第i項(xiàng)為空,則將關(guān)鍵字k及有關(guān)信息填入該項(xiàng);若第i項(xiàng)不空,則令i=mod(i0+RN(j),n),并令j=j+1(將隨機(jī)數(shù)指針指向下一個隨機(jī)數(shù)),轉(zhuǎn)③繼續(xù)檢查。⑵隨機(jī)Hash表的取出:①計算關(guān)鍵字k的Hash碼i0=i(k),且令i=i0②偽隨機(jī)數(shù)序列初始化,令j=1(將隨機(jī)數(shù)指針指向偽隨機(jī)數(shù)序列的第1個隨機(jī)數(shù))。③檢查表中第i項(xiàng)的內(nèi)容:若第i項(xiàng)登記著關(guān)鍵字k,則取出該項(xiàng)元素即可;若第i項(xiàng)為空,則表示在Hash表中沒有該關(guān)鍵字的信息;若第i項(xiàng)不空,且登記的不是關(guān)鍵字k,則令i=mod(i0+RN(j),n),并令j=j+1(將隨機(jī)數(shù)指針指向下一個隨機(jī)數(shù)),轉(zhuǎn)③繼續(xù)檢查。其中RN(j)表示偽隨機(jī)數(shù)序列RN中的第j個隨機(jī)數(shù)。3.溢出Hash表線性Hash表與隨機(jī)Hash表均存在兩個致命的缺點(diǎn):一是在Hash表填入過程中不顧后效,從而在填入過程中其沖突的機(jī)會在不斷增多;二是當(dāng)Hash表填滿時,不能正常地進(jìn)行查找。如果將沖突的元素安排在另外的空間內(nèi),而不占用Hash表本身的空間,則不會產(chǎn)生新的沖突,這就是溢出Hash表。

溢出Hash表包括Hash表和溢出表兩部分。在Hash表的填入過程中,將沖突的元素順序填入溢出表,而當(dāng)查找過程中發(fā)現(xiàn)沖突時,就在溢出表中進(jìn)行順序查找。溢出表的填入過程:①計算關(guān)鍵字k的Hash碼i=i(k).②檢查表中第i項(xiàng)的內(nèi)容:若第i項(xiàng)為空,則將關(guān)鍵字K及有關(guān)信息填入該項(xiàng);若第i項(xiàng)不空,則將關(guān)鍵字k及有關(guān)信息依次填入溢出表中的自由項(xiàng)。⑵溢出Hash表的取出:①計算關(guān)鍵字k的Hash碼i=i(k).②檢查表中第i項(xiàng)內(nèi)容:若第i項(xiàng)登記著關(guān)鍵字k,則取出該項(xiàng)元素即可;若第i項(xiàng)為空,則表示在Hash表中沒有該關(guān)鍵字的信息;若第i項(xiàng)不空,且登記的不是關(guān)鍵字k,則轉(zhuǎn)入在溢出表中進(jìn)行順序查找。4.拉鏈Hash表-1

拉鏈Hash表分為外鏈Hash表與內(nèi)鏈Hash表。我們只討論外鏈Hash表。外鏈Hash表由Hash表及表外結(jié)點(diǎn)所組成。在Hash表中登記的并不是關(guān)鍵字k及有關(guān)信息,而只是登記指針。⑴外鏈Hash表的填入:①計算關(guān)鍵字k的Hash碼i=i(k).②取得一個新結(jié)點(diǎn)p,并將關(guān)鍵字k及有關(guān)信息填入結(jié)點(diǎn)p。③將結(jié)點(diǎn)p鏈入以H(i)為頭指針的鏈表的鏈頭。4.拉鏈Hash表-2⑴外鏈Hash表

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論