搜尋
首頁後端開發C#.Net教程資料結構中散列表(雜湊表)經典之衝突處理

雜湊是在記錄的儲存位置和它的關鍵字之間建立一個確定的對應關係f,使得每個關鍵字key對應一個儲存位置f(key),建立了關鍵字與儲存位置的相互對應關係,這種關係f 稱為雜湊函數(雜湊函數)。本文小編主要講述雜湊函數的衝突處理問題。


資料結構中散列表(雜湊表)經典之衝突處理

在尋找過程中,關鍵碼的比較次數,取決於產生衝突的多少,產生的衝突少,查找效率就高,產生的衝突多,查找效率就低。因此,影響產生衝突多少的因素,也就是影響查找效率的因素。影響產生衝突多少有以下三個因素:

1. 雜湊函數是否均勻;

#2. 處理衝突的方法;

3. 散列函數是否均勻;

#2. 處理衝突的方法;

3. 散列表的裝填因子。

散列表的裝填因子定義為:α= 填入表中的元素個數 / 散列表的長度

α是散列表裝滿程度的標誌因子。由於表長是定值,α與「填入表中的元素個數」成正比,所以,α越大,填入表中的元素較多,產生衝突的可能性就越大;α越小,填入表中的元素較少,產生衝突的可能性就越小。

實際上,散列表的平均查找長度是裝填因子α的函數,只是不同處理衝突的方法有不同的函數。

解決雜湊衝突的方法一般有:

NO.1開放定址法

#所謂的開放定址法就是一旦發生了衝突,就去尋找下一個空的雜湊位址,只要散列表夠大,空的雜湊地址總是能找到,並將記錄存入。

公式:f(key)=(f(key) di)%m(di=1,2,3….m-1)

比如說,關鍵字集合為{ 12, 67, 56, 16, 25, 37, 22, 29, 15, 47, 48, 34},表長為12。雜湊函數f(key) = key mod 12。 當計算前5個數{12, 67, 56, 16, 25}時,都是沒有衝突的雜湊位址,直接存入;計算key = 37時,發現f(37) = 1,此時就與25所在的位置衝突。於是應用上面的公式f(37) = (f(37) 1) mod 12 =2,。於是將37存入下標為2的位置。接下來22,29,15,47都沒有衝突,正常的存入。到了48,計算得到f(48) = 0,與12所在的0位置衝突了,不要緊,我們f(48) = (f(48) 1) mod 12 = 1,此時又與25所在的位置衝突。於是f(48) = (f(48) 2) mod 12 = 2,還是衝突......一直到f(48) = (f(48) 6) mod 12 = 6時,才有空位,如下表所示。 ##3# 4567891011 關鍵字1267
序號 0 1 2

25


16


56


#########

NO.2再雜湊法

對於散列表來說,可以事先準備多個雜湊函數。

公式:fi(key)=RHi(key)(i=1,2,3…,k)

這裡RHi 就是不同的雜湊函數,可以把除留餘數、折疊、平方取中全部用上。每當發生雜湊位址衝突時,就換一個雜湊函數計算。

這種方法能夠使得關鍵字不產生聚集,但相應地也增加了計算的時間。

NO.3鏈結位址法(拉鍊法)

將所有關鍵字為同義詞的記錄儲存在一個單鍊錶中,稱這種表為同義詞子表,在散列表中只儲存所有同義詞子表前面的指標。對於關鍵字集合{12, 67, 56, 16, 25, 37, 22, 29, 15, 47, 48, 34},用前面同樣的12為餘數,進行除留餘數法,可以得到下圖結構。

資料結構中散列表(雜湊表)經典之衝突處理

NO.4建立公共溢出區

這個方法是當你時重新給你找個位址,為所有衝突的關鍵字建立一個公共的溢出區來存放。

就前面的例子而言,共有三個關鍵字37、48、34與先前的關鍵字位置有衝突,那就將它們儲存到溢出表中。如下圖所示。

資料結構中散列表(雜湊表)經典之衝突處理

在尋找時,對給定值透過雜湊函數計算出雜湊位址後,先與基本表的對應位置進行比對,如果相等,則尋找成功;如果不相等,則到溢出表中進行順序查找。如果相對於基本表而言,有衝突的資料很少的情況下,公共溢出區的結構對查找效能來說還是非常高的。

【推薦課程:C 相關課程

#

以上是資料結構中散列表(雜湊表)經典之衝突處理的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
C#.NET用於網絡,桌面和移動開發C#.NET用於網絡,桌面和移動開發Apr 25, 2025 am 12:01 AM

C#和.NET適用於Web、桌面和移動開發。 1)在Web開發中,ASP.NETCore支持跨平台開發。 2)桌面開發使用WPF和WinForms,適用於不同需求。 3)移動開發通過Xamarin實現跨平台應用。

C#.NET生態系統:框架,庫和工具C#.NET生態系統:框架,庫和工具Apr 24, 2025 am 12:02 AM

C#.NET生態系統提供了豐富的框架和庫,幫助開發者高效構建應用。 1.ASP.NETCore用於構建高性能Web應用,2.EntityFrameworkCore用於數據庫操作。通過理解這些工具的使用和最佳實踐,開發者可以提高應用的質量和性能。

將C#.NET應用程序部署到Azure/AWS:逐步指南將C#.NET應用程序部署到Azure/AWS:逐步指南Apr 23, 2025 am 12:06 AM

如何將C#.NET應用部署到Azure或AWS?答案是使用AzureAppService和AWSElasticBeanstalk。 1.在Azure上,使用AzureAppService和AzurePipelines自動化部署。 2.在AWS上,使用AmazonElasticBeanstalk和AWSLambda實現部署和無服務器計算。

C#.NET:強大的編程語言簡介C#.NET:強大的編程語言簡介Apr 22, 2025 am 12:04 AM

C#和.NET的結合為開發者提供了強大的編程環境。 1)C#支持多態性和異步編程,2).NET提供跨平台能力和並發處理機制,這使得它們在桌面、Web和移動應用開發中廣泛應用。

.NET框架與C#:解碼術語.NET框架與C#:解碼術語Apr 21, 2025 am 12:05 AM

.NETFramework是一個軟件框架,C#是一種編程語言。 1..NETFramework提供庫和服務,支持桌面、Web和移動應用開發。 2.C#設計用於.NETFramework,支持現代編程功能。 3..NETFramework通過CLR管理代碼執行,C#代碼編譯成IL後由CLR運行。 4.使用.NETFramework可快速開發應用,C#提供如LINQ的高級功能。 5.常見錯誤包括類型轉換和異步編程死鎖,調試需用VisualStudio工具。

揭開c#.net的神秘面紗:初學者的概述揭開c#.net的神秘面紗:初學者的概述Apr 20, 2025 am 12:11 AM

C#是一種由微軟開發的現代、面向對象的編程語言,.NET是微軟提供的開發框架。 C#結合了C 的性能和Java的簡潔性,適用於構建各種應用程序。 .NET框架支持多種語言,提供垃圾回收機制,簡化內存管理。

C#和.NET運行時:它們如何一起工作C#和.NET運行時:它們如何一起工作Apr 19, 2025 am 12:04 AM

C#和.NET運行時緊密合作,賦予開發者高效、強大且跨平台的開發能力。 1)C#是一種類型安全且面向對象的編程語言,旨在與.NET框架無縫集成。 2).NET運行時管理C#代碼的執行,提供垃圾回收、類型安全等服務,確保高效和跨平台運行。

C#.NET開發:入門的初學者指南C#.NET開發:入門的初學者指南Apr 18, 2025 am 12:17 AM

要開始C#.NET開發,你需要:1.了解C#的基礎知識和.NET框架的核心概念;2.掌握變量、數據類型、控制結構、函數和類的基本概念;3.學習C#的高級特性,如LINQ和異步編程;4.熟悉常見錯誤的調試技巧和性能優化方法。通過這些步驟,你可以逐步深入C#.NET的世界,並編寫高效的應用程序。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能