亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++哈希表之線性探測法實現(xiàn)詳解

 更新時間:2022年05月04日 10:50:24   作者:liufeng2023  
線性探測法的優(yōu)點:只要散列表未滿,總能找到一個不沖突的散列地址;缺點:每個產(chǎn)生沖突的記錄被散列到離沖突最近的空地址上,從而又增加了更多的沖突機會

1、哈希表-線性探測法理論

在這里插入圖片描述

線性探測法的理論我們在上一篇博客已經(jīng)闡述了。

現(xiàn)在我們來看看線性探測法的增刪查的代碼思想:

1.1、哈希表的增加元素

在這里插入圖片描述

注意:

往后遍歷尋找空閑位置的時候,要注意是環(huán)形遍歷哦!不然訪問數(shù)組就越界了。

在添加元素,發(fā)生位置被占用,即發(fā)生哈希沖突后,在向后遍歷尋找空閑位置的時候,我們要知道,這個空閑的位置是有兩種情況的:

1、這個位置一直是空的,沒放過元素。

2、這個位置是空的,以前放過元素,后來被刪除了。

1.2、哈希表的查詢操作

在這里插入圖片描述

在這里插入圖片描述

  • 當用哈希函數(shù)計算得出的下標值是3,然后去訪問數(shù)組,查詢時,發(fā)現(xiàn)該值不等于要查詢的元素的值val,說明當時放val的時候發(fā)生了哈希沖突,這時候就要向后遍歷了;
  • 訪問4下標的時候發(fā)現(xiàn)這個位置是空的(空的有兩種情況),如果這個位置一直是空的,則就不用繼續(xù)向后找了,val不存在!因為是線性探測法,所以當時val如果要放的時候肯定是要放在這里的。
  • 但是如果這個位置是空的,但是之前放過元素,后來被刪除了,這個位置之前存放了元素,然后val插入的時候,就插到后面的空閑的位置了,所以此時我們還要繼續(xù)往后遍歷尋找val值。

在這里插入圖片描述

所以我們需要定義一個Bucket節(jié)點來表示每一個元素的所有的內(nèi)容。

在這里插入圖片描述

//桶的狀態(tài)
enum State
{
	STATE_UNUSE, //從未使用過的桶
	STATE_USING, //正在使用的桶 放著是一個有效的元素,沒有被刪過 
	STATE_DEL,  //元素被刪除了的桶,認為桶里的元素無效了 
};
//我們刪除桶里的元素,并不是真正把值刪除掉,而是把桶的狀態(tài)置為STATE_DEL就認為桶里的元素無效了 
//桶的類型
struct Bucket
{
	Bucket(int key = 0, State state = STATE_UNUSE)
		: key_(key)
		, state_(state)
	{}
	int key_;      //存儲的數(shù)據(jù)
	State state_;  //桶的當前狀態(tài)
};

1.3、哈希表的刪除操作

在這里插入圖片描述

2、哈希表-線性探測法代碼實現(xiàn)

2.1、素數(shù)表中的素數(shù)

求素數(shù)的代碼:(用于素數(shù)表中的素數(shù)取值)

在這里插入圖片描述

在這里插入圖片描述

int main()
{
	int data = 3;
	for (int i = data; i < 10000; i++)
	{
		int j = 2;
		for (; j < i; j++)
		{
			if (i % j == 0)
				break;
		}
		if (j == i)
			cout << i << " ";
	}
	cout << endl;
	return 0;
}

到此這篇關(guān)于C++哈希表之線性探測法詳解使用的文章就介紹到這了,更多相關(guān)C++線性探測法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++ 編寫DLL文件給易語言調(diào)用方法

    C++ 編寫DLL文件給易語言調(diào)用方法

    在本文中我們給大家分享了C++ 編寫DLL文件給易語言調(diào)用的代碼和方法,需要的朋友們學習下。
    2019-01-01
  • c++實現(xiàn)簡單的線程池

    c++實現(xiàn)簡單的線程池

    這里給大家介紹了C++中對于pthread線程的一個簡單應(yīng)用以及使用繼承CDoit,實現(xiàn)其中的start和end,有需要的小伙伴可以參考下
    2015-11-11
  • C++11中匿名函數(shù)lambda的使用詳解

    C++11中匿名函數(shù)lambda的使用詳解

    我最早接觸lambda的概念是在matlab中,那時候在做數(shù)值模擬的課題,lambda可以快速定義簡單的函數(shù),當時覺得好方便。任何語言都有這個功能,下面來看看C++11新引入的lambda是如何使用的吧
    2023-04-04
  • 在C語言里單引號和雙引號的區(qū)別

    在C語言里單引號和雙引號的區(qū)別

    這篇文章主要介紹了在C語言里單引號和雙引號的區(qū)別,本文通過代碼的實例和注釋的詳細的說明了單引號和雙引號的概念與區(qū)別,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++中實現(xiàn)線程安全和延遲執(zhí)行詳解

    C++中實現(xiàn)線程安全和延遲執(zhí)行詳解

    這篇文章主要為大家詳細介紹了C++中實現(xiàn)線程安全和延遲執(zhí)行的相關(guān)知識,文中的示例代碼講解詳細,具有一定的借鑒價值,需要的小伙伴可以了解下
    2024-01-01
  • C++算法與泛型算法(algorithm、numeric)

    C++算法與泛型算法(algorithm、numeric)

    這篇文章主要介紹了C++算法與泛型算法(algorithm、numeric),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-02-02
  • 利用C語言實現(xiàn)掃雷小游戲

    利用C語言實現(xiàn)掃雷小游戲

    這篇文章主要為大家詳細介紹了利用C語言實現(xiàn)掃雷小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-02-02
  • 詳解C語言中fseek函數(shù)和ftell函數(shù)的使用方法

    詳解C語言中fseek函數(shù)和ftell函數(shù)的使用方法

    這篇文章主要介紹了C語言中fseek函數(shù)和ftell函數(shù)的使用方法,兩個函數(shù)分別用于設(shè)置和返回文件指針stream的位置,需要的朋友可以參考下
    2016-03-03
  • c++ vector模擬實現(xiàn)的全過程

    c++ vector模擬實現(xiàn)的全過程

    這篇文章主要給大家介紹了關(guān)于c++ vector的模擬實現(xiàn)過程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • C++中小數(shù)點輸出格式(實例代碼)

    C++中小數(shù)點輸出格式(實例代碼)

    下面小編就為大家?guī)硪黄狢++中小數(shù)點輸出格式(實例代碼)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06

最新評論