亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++哈希表之線性探測法怎么實現

發布時間:2022-05-07 17:37:36 來源:億速云 閱讀:232 作者:iii 欄目:開發技術

今天小編給大家分享一下C++哈希表之線性探測法怎么實現的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

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

C++哈希表之線性探測法怎么實現

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

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

1.1、哈希表的增加元素

C++哈希表之線性探測法怎么實現

注意:

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

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

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

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

1.2、哈希表的查詢操作

C++哈希表之線性探測法怎么實現

C++哈希表之線性探測法怎么實現

  • 當用哈希函數計算得出的下標值是3,然后去訪問數組,查詢時,發現該值不等于要查詢的元素的值val,說明當時放val的時候發生了哈希沖突,這時候就要向后遍歷了;

  • 訪問4下標的時候發現這個位置是空的(空的有兩種情況),如果這個位置一直是空的,則就不用繼續向后找了,val不存在!因為是線性探測法,所以當時val如果要放的時候肯定是要放在這里的。

  • 但是如果這個位置是空的,但是之前放過元素,后來被刪除了,這個位置之前存放了元素,然后val插入的時候,就插到后面的空閑的位置了,所以此時我們還要繼續往后遍歷尋找val值。

C++哈希表之線性探測法怎么實現

所以我們需要定義一個Bucket節點來表示每一個元素的所有的內容。

C++哈希表之線性探測法怎么實現

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

1.3、哈希表的刪除操作

C++哈希表之線性探測法怎么實現

2、哈希表-線性探測法代碼實現

2.1、素數表中的素數

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

C++哈希表之線性探測法怎么實現

C++哈希表之線性探測法怎么實現

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;
}

以上就是“C++哈希表之線性探測法怎么實現”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

应用必备| 永泰县| 谷城县| 达日县| 乌拉特后旗| 百色市| 开远市| 天水市| 沭阳县| 洪泽县| 昌黎县| 甘泉县| 神木县| 依安县| 贵定县| 泉州市| 隆子县| 项城市| 乌拉特中旗| 马公市| 揭阳市| 娱乐| 卫辉市| 尉犁县| 普陀区| 兖州市| 古蔺县| 紫云| 临夏市| 邯郸市| 蛟河市| 恩平市| 巩义市| 庄河市| 荆门市| 泸水县| 理塘县| 榕江县| 静安区| 伽师县| 文成县|