雜湊是在記錄的儲存位置和它的關鍵字之間建立一個確定的對應關係f,使得每個關鍵字key對應一個儲存位置f(key),建立了關鍵字與儲存位置的相互對應關係,這種關係f 稱為雜湊函數(雜湊函數)。本文小編主要講述雜湊函數的衝突處理問題。
在尋找過程中,關鍵碼的比較次數,取決於產生衝突的多少,產生的衝突少,查找效率就高,產生的衝突多,查找效率就低。因此,影響產生衝突多少的因素,也就是影響查找效率的因素。影響產生衝突多少有以下三個因素:
1. 雜湊函數是否均勻;
#2. 處理衝突的方法;
3. 散列函數是否均勻;
#2. 處理衝突的方法;
3. 散列表的裝填因子。
散列表的裝填因子定義為:α= 填入表中的元素個數 / 散列表的長度
α是散列表裝滿程度的標誌因子。由於表長是定值,α與「填入表中的元素個數」成正比,所以,α越大,填入表中的元素較多,產生衝突的可能性就越大;α越小,填入表中的元素較少,產生衝突的可能性就越小。
實際上,散列表的平均查找長度是裝填因子α的函數,只是不同處理衝突的方法有不同的函數。
解決雜湊衝突的方法一般有:
NO.1開放定址法
#所謂的開放定址法就是一旦發生了衝突,就去尋找下一個空的雜湊位址,只要散列表夠大,空的雜湊地址總是能找到,並將記錄存入。
公式:f(key)=(f(key) di)%m(di=1,2,3….m-1)
序號 | 0 | 1 | 2 | ##3# 4 | 5 | 6 | 7 | 8 | 9 | 10 | ||
關鍵字 | 12 |
25 |
16 |
67 |
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中文網其他相關文章!

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

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

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

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

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

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

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

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


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

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

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

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

SublimeText3 Linux新版
SublimeText3 Linux最新版

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能