哈希表---闭散列

闭散列

当我们用哈希函数的时候,其中一个就是除留余数法

取这个表的长度len,按照哈希函数:Hash(key) = key% len,将这个位置映射到表中

通过上面的除留余数法,会有哈希碰撞 的问题,可以通过闭散列来解决

闭散列 也叫开放定址法,通过线性探测,依次找后面的位置存储

插入

哈希表数据定义

cpp 复制代码
enum State
{
	EMPTY,
	EXIST,
	DELETE
};

template<class K, class V>
struct HashData
{
	pair<K, V> _kv;
	State _state=EMPTY;
};

哈希表的底层可以用vector封装

cpp 复制代码
template<class K,class V>
class HashTable
{
public:
	
	bool insert(const pair<K,V>& kv)
	{
		
	...........
	}

private:
	vector<HashData<K, V>> _ht;
	size_t _n = 0;//记录表中数据个数
};

插入问题1

当用除留余数法的时,除以的的vector的capacity还是size呢?

cpp 复制代码
bool insert(const pair<K,V>& kv)
	{    
        int hashi = kv.first% _ht.size();
		int index = hashi;
		int i = 1;
		while (_ht[index]._state ==EXIST)
		{
			index = hashi + i;
			index %= _ht.size();
			i++;
		}
		_ht[index]._kv = kv;
		_ht[index]._state = EXIST;
		_n++;
     }

答案是size,因为用vector的[ ]的时候,是只能访问size的部分的,假如是capacity,算出来的值可以就大于size了,就无法访问了

插入问题2

是不是有疑惑,当size==0的时候怎么处理?那就要扩容了

还有什么情况下要扩容?

在载荷因子较大的情况下要进行扩容

插入问题3

怎么扩容?

你们的脑瓜子一想简单啦,直接用vector的reserve就好啦,不对的,vector的reserve是扩大了capacity,size没有变的

我们可以用resize进行扩容,risize既扩容又初始化,size改变了

再把旧表数据移到新表

cpp 复制代码
	bool insert(const pair<K,V>& kv)
	{
		if (Find(kv.first))
			return false;
		if (_ht.size()==0||_n * 10 / _ht.size() >= 7)
		{
			int newsize = _ht.size() == 0 ? 10 : _ht.size() * 2;
			HashTable<K, V> newht;
			//对原来insert进行复用
			newht._ht.resize(newsize);

			//遍历旧表,来初始化新表
			for (auto& data : _ht)
			{
				if (data._state == EXIST)
				{
					newht.insert(data._kv);
				}

			}
			_ht.swap(newht._ht);
		}
        //线性探测
		int hashi = kv.first% _ht.size();
		int index = hashi;
		int i = 1;
		while (_ht[index]._state ==EXIST)
		{
			index = hashi + i;
			index %= _ht.size();
			i++;
		}
		_ht[index]._kv = kv;
		_ht[index]._state = EXIST;
		_n++;
		return true;
	}
相关推荐
GalaxyPokemon3 分钟前
LeetCode - 53. 最大子数组和
算法·leetcode·职场和发展
小猫咪怎么会有坏心思呢6 分钟前
华为OD机考 - 水仙花数 Ⅰ(2025B卷 100分)
数据结构·链表·华为od
weixin_4786897622 分钟前
C++ 对 C 的兼容性
java·c语言·c++
k要开心27 分钟前
C++概念以及基础框架语法
开发语言·c++
hn小菜鸡39 分钟前
LeetCode 1356.根据数字二进制下1的数目排序
数据结构·算法·leetcode
zhuiQiuMX43 分钟前
分享今天做的力扣SQL题
sql·算法·leetcode
weixin_307779131 小时前
Linux下GCC和C++实现统计Clickhouse数据仓库指定表中各字段的空值、空字符串或零值比例
linux·运维·c++·数据仓库·clickhouse
music&movie2 小时前
算法工程师认知水平要求总结
人工智能·算法
秦少游在淮海2 小时前
C++ - string 的使用 #auto #范围for #访问及遍历操作 #容量操作 #修改操作 #其他操作 #非成员函数
开发语言·c++·stl·string·范围for·auto·string 的使用
const5442 小时前
cpp自学 day2(—>运算符)
开发语言·c++