C++:哈希表的线性探测(模拟实现)

哈希表的增删查改的效率很高,是O(1),比搜索二叉树要快很多。那么他是怎么实现的呢?他与计数排序有点相似就是通过映射的方式实现。不过在哈希表中不需要开这么的数据,它只需要开一部分空间然后使用除留余数法去实现,这个方法的缺点就是会导致哈希冲突很集中。并且哈希表是不能满的,因为哈希表要控制他的负载因子(负载因子 = 表中数据/表的大小 衡量哈希表满的程度。负载因子越大,增删查改的效率越低。一般负载因子在0.7左右开始增容。但是负载因子越小,浪费空间越多,以下是代码实现

	enum State{EMPTY, EXITS, DELETE,};template<class T>struct HashData{T _data;State _state;//用于查看下一个位置是是被删除还是本来就是空的};template<class K, class T, class KOFV>class HashTable{typedef HashData<T> HashData;public:bool Insert(const T& d){//负载因子 = 表中数据/表的大小 衡量哈希表满的程度//负载因子越大,增删查改的效率越低//一般负载因子在0.7左右开始增容//但是负载因子越小,浪费空间越多KOFV kofv;if (_table.size() == 0 || _num * 10 / _table.size() > 7){//开新空间并且拷贝过去//重新映射//释放旧空间//int newcapacity = _table.size() == 0 ? 10 : _table.size() * 2;//vector<HashData> newtable;//newtable.resize(newcapacity);//for (int i = 0; i < _table.size(); i++)//{//	int index = kofv(_table[i]._data) % newtable.size();//	if (newtable[i]._state == EXITS)//	{//		while (_table[index]._state == EXITS)//		{//			++index;//			if (index == _table.size())//				index = 0;//		}//	}//	newtable[index]= _table[i];//}//_table.swap(newtable);HashTable<K, T, KOFV> newht;int newcapacity = _table.size() == 0 ? 10 : _table.size() * 2;newht._table.resize(newcapacity);for (int i = 0; i < _table.size(); i++){if (_table[i]._state == EXITS){newht.Insert(_table[i]._data);}}_table.swap(newht._table);}int index = kofv(d) % _table.size();while (_table[index]._state == EXITS){if (_table[index]._data == kofv(d))return false;++index;if (index == _table.size())index = 0;}_table[index]._data = d;_table[index]._state = EXITS;++_num;return true;}HashData* Find(const K& key){KOFV kofv;int index = key % _table.size();//if (key == kofv(_table[index]._data))//{//	if (_table[index]._stata == EXITS)//		return &_table[index];//	else//DELETE//		return nullptr;//}//else//{//	++index;//	if (_table[index]._state == EMPTY)//	{//		return nullptr;//	}//	else//	{//		{//			++index;//			if (index == _table.size())//				index = 0;//		}//		return &_table[index];//	}//}while (_table[index]._state != EMPTY){if (kofv(_table[index]._data) == key){if (_table[index]._state == EXITS)return &_table[index];elsereturn nullptr;}++index;if (index == _table.size())index = 0;}return nullptr;}bool Erase(const K& key){HashData* ret = Find(key);if (ret){ret->_state = DELETE;--_num;return true;}else{return false;}}private:vector<HashData> _table;size_t    _num = 0;};template<class K>struct SetkeyOfv{const K& operator()(const K& key){return key;}};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/669544.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【算法与数据结构】583、72、LeetCode两个字符串的删除操作+编辑距离

文章目录 一、583、两个字符串的删除操作二、72、编辑距离三、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、583、两个字符串的删除操作 思路分析&#xff1a;本题的思路和115、不同的子序列差不多&#xff0c;只是变成…

【Java EE初阶十】多线程进阶二(CAS等)

1. 关于CAS CAS: 全称Compare and swap&#xff0c;字面意思:”比较并交换“&#xff0c;且比较交换的是寄存器和内存&#xff1b; 一个 CAS 涉及到以下操作&#xff1a; 下面通过语法来进一步进项说明&#xff1a; 下面有一个内存M&#xff0c;和两个寄存器A,B; CAS(M,A,B)&am…

minio怎么创建bucket

在使用docker-compose安装的MinIO环境中创建bucket&#xff08;存储桶&#xff09;通常涉及到使用MinIO的客户端工具mc&#xff08;MinIO Client&#xff09;。以下是如何使用mc来创建一个名为ability-bucket的bucket的步骤&#xff1a; 步骤 1: 下载并配置mc客户端 下载mc&am…

比较Kamailio和OpenSIPS的重写contact函数

Kamailio&#xff1a;调用set_contact_alias()之后&#xff0c;在原有的contact的后面增加参数&#xff0c;具体地说&#xff0c;就是网络地址&#xff0c;网络端口和transport&#xff0c;好处是收到后续请求之时可以恢复原有contact的内容 OpenSIPS&#xff1a;调用fix_nate…

synchronized内部工作原理

作者简介&#xff1a; zoro-1&#xff0c;目前大二&#xff0c;正在学习Java&#xff0c;数据结构&#xff0c;javaee等 作者主页&#xff1a; zoro-1的主页 欢迎大家点赞 &#x1f44d; 收藏 ⭐ 加关注哦&#xff01;&#x1f496;&#x1f496; synchronized内部工作原理 syn…

矿泉水市场调研:预计2029年将达到83亿美元

矿泉水为国民饮水消费升级的方向&#xff0c;估算我国矿泉水市场规模约472亿元&#xff0c;成长性好。我们按照水种将包装水划分为矿泉水、纯净水、天然水及其他&#xff0c;根据多个第三方数据来源数据&#xff0c;我们估算矿泉水2017年瓶装与桶装合计市场销售规模约472亿元&a…

深入理解指针(3)

⽬录 1. 字符指针变量 2. 数组指针变量 3. ⼆维数组传参的本质 4. 函数指针变量 5. 函数指针数组 6. 转移表 1. 字符指针变量 在指针的类型中我们知道有⼀种指针类型为字符指针 char* ; ⼀般使⽤: int main() {char ch w;char *pc &ch;*pc w;return 0; } 还有…

属性“xxxx”在类型“ArrayConstructor”上不存在。是否需要更改目标库? 请尝试将 “lib” 编译器选项更改为“es2015”或更高版本。

使用vscode编写vue&#xff0c;在使用elementUI时&#xff0c;发现代码中的form报错如下&#xff1a; 属性“form”在类型“ArrayConstructor”上不存在。是否需要更改目标库? 请尝试将 “lib” 编译器选项更改为“es2015”或更高版本。 解决方法&#xff1a; 打开jsconfig.…

Springboot拦截器+redis实现暴力请求拦截

在实际项目开发部署过程中&#xff0c;我们需要保证服务的安全性和可用性&#xff0c;当项目部署到服务器后&#xff0c;就要考虑服务被恶意请求和暴力攻击的情况。如何防止我们对外的接口被暴力攻击&#xff1f;下面的教程&#xff0c;通过Springboot提供的拦截器和Redis 针对…

快速掌握Vue.js框架:从入门到实战

一、引言 Vue.js,作为一款广受欢迎的渐进式JavaScript框架,以其轻量级、易用性和高效性在前端开发领域占据了一席之地。Vue.js遵循MVVM(Model-View-ViewModel)设计模式,它通过双向数据绑定机制简化了开发者对用户界面与底层数据模型之间关系的处理,使得构建现代Web应用变…

TOP100-二叉数

1.94. 二叉树的中序遍历 给定一个二叉树的根节点 root &#xff0c;返回 它的 中序 遍历 。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[1,3,2]示例 2&#xff1a; 输入&#xff1a;root [] 输出&#xff1a;[]示例 3&#xff1a; 输入&#xf…

第8章 多线程

8.1 线程概述 人们在日常生活中&#xff0c;很多事情都是可以同时进行的。例如&#xff0c;一个人可以一边听音乐&#xff0c;一边打扫房间&#xff0c;可以一边吃饭&#xff0c;一边看电视。在使用计算机时&#xff0c;很多任务也是可以同时进行的。例如&#xff0c;可以一边…

uniapp uni.redirectTo() 跳转失效

原代码&#xff1a; uni.redirectTo({url: /pages/mine/Mine }) 想实现的效果是用户登录成功后跳转至”我的“页面&#xff0c;但是点击登录按钮后可以成功打印出登录信息&#xff0c;却不跳转页面。 原因是我在 tabBar 中配置了 Mine 页面。 "tabBar": {"b…

对多面体数据进行裁剪和加盖的功能

开发环境&#xff1a; Windows 11 家庭中文版Microsoft Visual Studio Community 2019VTK-9.3.0.rc0vtk-example demo解决问题&#xff1a;对多面体数据进行裁剪和加盖的功能。 关键点&#xff1a; 创建了一个平面&#xff0c;并将其定位在输入多面体数据的中心位置&#xff…

详解洛谷P1352 没有上司的舞会(树形DP经典例题)

题目 没有上司的舞会 - 洛谷 思路 这是一道非常裸的树形DP&#xff0c;对于初学树形DP的OIer来说&#xff0c;是一道十分良心的题 我们可以设: dp[x][0]表示以x为根的子树,且x不参加舞会的最大快乐值 dp[x][1]表示以x为根的子树&#xff0c;且x参加了舞会的最大快乐值 则有 …

爬虫工作量由小到大的思维转变---<第四十四章 Scrapyd 用gerapy管理多台机器爬虫>

前言: 之前讲过关于如何在gerapy中部署本地爬虫, 爬虫工作量由小到大的思维转变---&#xff1c;第三十四章 Scrapy 的部署scrapydGerapy&#xff1e;_gerapy如何登录-CSDN博客 爬虫工作量由小到大的思维转变---&#xff1c;第三十五章 Scrapy 的scrapydGerapy 部署爬虫项目&…

SpringBoot:配置相关知识点

SpringBoot&#xff1a;多环境配置 配置知识点demo&#xff1a;点击查看LearnSpringBoot02 点击查看更多的SpringBoot教程 一、SpringBootApplication SpringBootApplication 来标注一个主程序类&#xff0c;说明这是一个Spring Boot应用&#xff0c;运行这个类的main方法来…

睿尔曼超轻量仿人机械臂-- RM65-B手眼标定使用说明

一、前言 机器人的视觉系统分为固定场景视觉系统和运动的「手-眼」视觉系统。相机与机器人手臂末端&#xff0c;构成手眼视觉系统。根据相机在机器人安装位置的不同&#xff0c;手眼视觉系统分为Eye-in-Hand系统&#xff08;眼在手上&#xff09;和Eye-to-Hand系统&#xff08…

Javascript | 打印菱形

Javascript打印菱形&#xff0c;在校大学生可以拿来糊弄作业&#xff08;笑&#xff09; var str ; for (var i 1; i < 9; i) {if (i < 5) {for (var k1 1; k1 < 5 - i; k1) {str ;}} else {for (var k2 1; k2 < i - 5; k2) {str ;}}if (i < 5) {for (…

Curl 使用指南(进阶版)

使用Curl可以轻松GET资源、发送POST请求、定制HTTP头。高级技巧如代理、Cookie、证书 一、Curl 的基本用法 curl [options] [URL]options &#xff1a;指定 Curl 的行为的选项 URL &#xff1a;要访问的资源的地址 支持一下&#xff1a; Python Gui图形化开发 MySQL使用教程 …