C 语言

关注公众号 jb51net

关闭
首页 > 软件编程 > C 语言 > C++线性探测法

C++哈希表之线性探测法实现详解

作者:liufeng2023

线性探测法的优点:只要散列表未满,总能找到一个不冲突的散列地址;缺点:每个产生冲突的记录被散列到离冲突最近的空地址上,从而又增加了更多的冲突机会

1、哈希表-线性探测法理论

在这里插入图片描述

线性探测法的理论我们在上一篇博客已经阐述了。

现在我们来看看线性探测法的增删查的代码思想:

1.1、哈希表的增加元素

在这里插入图片描述

注意:

往后遍历寻找空闲位置的时候,要注意是环形遍历哦!不然访问数组就越界了。

在添加元素,发生位置被占用,即发生哈希冲突后,在向后遍历寻找空闲位置的时候,我们要知道,这个空闲的位置是有两种情况的:

1、这个位置一直是空的,没放过元素。

2、这个位置是空的,以前放过元素,后来被删除了。

1.2、哈希表的查询操作

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

所以我们需要定义一个Bucket节点来表示每一个元素的所有的内容。

在这里插入图片描述

//桶的状态
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、哈希表的删除操作

在这里插入图片描述

2、哈希表-线性探测法代码实现

2.1、素数表中的素数

求素数的代码:(用于素数表中的素数取值)

在这里插入图片描述

在这里插入图片描述

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++哈希表之线性探测法详解使用的文章就介绍到这了,更多相关C++线性探测法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文