目录1、哈希表-线性探测法理论1.1、哈希表的增加元素1.2、哈希表的查询操作1.3、哈希表的删除操作2、哈希表-线性探测法代码实现2.1、素数表中的素数1、哈希表-线性探测法理论
线性探测法的理论我们在上一篇博客已经阐述了。
现在我们来看看线性探测法的增删查的代码思想:
注意:
往后遍历寻找空闲位置的时候,要注意是环形遍历哦!不然访问数组就越界了。
在添加元素,发生位置被占用,即发生哈希冲突后,在向后遍历寻找空闲位置的时候,我们要知道,这个空闲的位置是有两种情况的:
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_; //桶的当前状态
};
求素数的代码:(用于素数表中的素数取值)
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++线性探测法内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: C++哈希表之线性探测法实现详解
本文链接: https://lsjlt.com/news/147877.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0