探索哈希表:C++中的实现与操作详解【Map、Set、数据结构】
探索哈希表:C++中的实现与操作详解
介绍
哈希表(Hash Table)是一种常见的数据结构,它提供了一种高效的键值对存储方式,能够快速进行插入、删除和查找操作。在这篇博客中,我们将详细介绍哈希表的概念、在C++中的实现方式以及常见操作的示例。我们还会讨论 unordered_set,一种用于集合操作的哈希表,常用于需要去重的场景。
什么是哈希表?
哈希表是一种通过哈希函数将键映射到存储桶(Bucket)或槽(Slot)中的数据结构。其核心思想是使用哈希函数将键转换为数组的索引,从而能够在常数时间内(平均情况下)进行查找、插入和删除操作。
哈希表的基本概念
- 哈希函数:将输入的键转换为数组的索引。
- 存储桶:数组中的位置,每个存储桶可以存储一个或多个键值对。
- 冲突处理:当两个不同的键被哈希到相同的索引时,需要解决冲突。常见的冲突处理方法有链地址法(Chaining)和开放地址法(Open Addressing)。
在C++中实现哈希表
在C++中,我们可以使用STL库中的unordered_map来实现哈希表。unordered_map是一个关联容器,提供了哈希表的所有基本操作。下面是一个简单的示例:
示例代码
#include <iostream>
#include <unordered_map>
#include <string>int main() {// 创建一个unordered_mapstd::unordered_map<std::string, int> hashTable;// 插入键值对hashTable["apple"] = 1;hashTable["banana"] = 2;hashTable["orange"] = 3;// 查找键值对std::string key = "banana";if (hashTable.find(key) != hashTable.end()) {std::cout << key << " found with value " << hashTable[key] << std::endl;} else {std::cout << key << " not found" << std::endl;}// 删除键值对hashTable.erase("orange");// 遍历哈希表for (const auto& pair : hashTable) {std::cout << pair.first << ": " << pair.second << std::endl;}return 0;
}
详细实现与操作
-
创建哈希表
- 使用
std::unordered_map可以很方便地创建一个哈希表。键和值的类型可以根据需要进行指定。
std::unordered_map<std::string, int> hashTable; - 使用
-
插入键值对
- 可以使用下标操作符或
insert方法来插入键值对。
hashTable["apple"] = 1; hashTable["banana"] = 2; hashTable.insert({"orange", 3}); - 可以使用下标操作符或
-
查找键值对
- 使用
find方法可以查找键是否存在于哈希表中,返回一个迭代器。如果键存在,迭代器指向键值对;否则,迭代器指向end。
std::string key = "banana"; if (hashTable.find(key) != hashTable.end()) {std::cout << key << " found with value " << hashTable[key] << std::endl; } else {std::cout << key << " not found" << std::endl; } - 使用
-
删除键值对
- 使用
erase方法可以删除指定键的键值对。
hashTable.erase("orange"); - 使用
-
遍历哈希表
- 可以使用范围循环或迭代器遍历哈希表中的所有键值对。
for (const auto& pair : hashTable) {std::cout << pair.first << ": " << pair.second << std::endl; }
unordered_set的讲解与使用场景
unordered_set是什么?
unordered_set 是 C++ 标准模板库(STL)中的一种集合容器,它基于哈希表实现,用于存储不重复的元素。与 unordered_map 类似,unordered_set 提供了快速的插入、删除和查找操作。
unordered_set的典型使用场景
unordered_set 最常用于需要去重的场景。例如,我们有一个包含重复元素的数组,需要快速去重并保留唯一元素。在这种情况下,unordered_set 是一个理想的选择。
示例代码
#include <iostream>
#include <unordered_set>
#include <vector>int main() {// 创建一个unordered_setstd::unordered_set<int> hashSet;// 插入元素hashSet.insert(1);hashSet.insert(2);hashSet.insert(3);hashSet.insert(2); // 插入重复元素// 查找元素int key = 2;if (hashSet.find(key) != hashSet.end()) {std::cout << key << " found in the set" << std::endl;} else {std::cout << key << " not found in the set" << std::endl;}// 删除元素hashSet.erase(2);// 遍历哈希集合for (const auto& elem : hashSet) {std::cout << elem << " ";}std::cout << std::endl;// 使用unordered_set去重std::vector<int> nums = {1, 2, 3, 4, 5, 1, 2, 3};std::unordered_set<int> uniqueNums(nums.begin(), nums.end());// 输出去重后的结果for (const auto& elem : uniqueNums) {std::cout << elem << " ";}std::cout << std::endl;return 0;
}
详细实现与操作
-
创建哈希集合
- 使用
std::unordered_set可以方便地创建一个集合,用于存储不重复的元素。
std::unordered_set<int> hashSet; - 使用
-
插入元素
- 可以使用
insert方法来插入元素。重复的元素不会被插入到集合中。
hashSet.insert(1); hashSet.insert(2); hashSet.insert(3); hashSet.insert(2); // 插入重复元素 - 可以使用
-
查找元素
- 使用
find方法可以查找元素是否存在于集合中,返回一个迭代器。如果元素存在,迭代器指向元素;否则,迭代器指向end。
int key = 2; if (hashSet.find(key) != hashSet.end()) {std::cout << key << " found in the set" << std::endl; } else {std::cout << key << " not found in the set" << std::endl; } - 使用
-
删除元素
- 使用
erase方法可以删除指定的元素。
hashSet.erase(2); - 使用
-
遍历哈希集合
- 可以使用范围循环或迭代器遍历集合中的所有元素。
for (const auto& elem : hashSet) {std::cout << elem << " "; } std::cout << std::endl; -
使用
unordered_set去重- 可以将一个包含重复元素的数组转换为
unordered_set,从而实现去重。
std::vector<int> nums = {1, 2, 3, 4, 5, 1, 2, 3}; std::unordered_set<int> uniqueNums(nums.begin(), nums.end());// 输出去重后的结果 for (const auto& elem : uniqueNums) {std::cout << elem << " "; } std::cout << std::endl; - 可以将一个包含重复元素的数组转换为
总结
哈希表是一种高效的数据结构,广泛应用于需要快速查找、插入和删除操作的场景中。在C++中,std::unordered_map 和 std::unordered_set 提供了便捷的哈希表实现。通过本文的介绍和示例代码,我们了解了哈希表的基本概念及其在C++中的实现和常见操作。希望这些内容能帮助你更好地理解和使用哈希表。
相关文章:
探索哈希表:C++中的实现与操作详解【Map、Set、数据结构】
探索哈希表:C中的实现与操作详解 介绍 哈希表(Hash Table)是一种常见的数据结构,它提供了一种高效的键值对存储方式,能够快速进行插入、删除和查找操作。在这篇博客中,我们将详细介绍哈希表的概念、在C中的…...
Python酷库之旅-第三方库Pandas(062)
目录 一、用法精讲 241、pandas.Series.view方法 241-1、语法 241-2、参数 241-3、功能 241-4、返回值 241-5、说明 241-6、用法 241-6-1、数据准备 241-6-2、代码示例 241-6-3、结果输出 242、pandas.Series.compare方法 242-1、语法 242-2、参数 242-3、功能 …...
python学习之旅(基础篇看这篇足够了!!!)
目录 前言 1.输入输出 1.1 输入 1.2 输出 2. 变量与常量 2.1 变量 2.2 常量 2.3 赋值 2.4格式化输出 3. 数据类型 4. 四则运算 5.“真与假” 5.1 布尔数 5.2 比较运算和逻辑运算 5.3 布尔表达式 6.判断语句 6.1 基本的if语句 6.2 if-else语句 6.3 if-elif-el…...
Azure OpenAI Embeddings vs OpenAI Embeddings
题意:Azure OpenAI 嵌入与 OpenAI 嵌入的比较 问题背景: Is anyone getting different results from Azure OpenAI embeddings deployment using text-embedding-ada-002 than the ones from OpenAI? Same text, same model, and the results are cons…...
重生奇迹MU职业成长三步走
在重生奇迹MU游戏中,转职是最重要的玩法之一。每个职业在转职后都会发生巨大的变化,经过三次转职后,你才有资格成为该游戏中最强大的冒险者。 一转,一切才刚刚开始 玩家完成第一次转职任务后,标志着我们成功度过了游…...
2024年中国数据中台行业研究报告
数据中台丨研究报告 核心摘要: 数据中台是企业数字化建设的重要构成,其通过整合企业基础设施和数据能力,实现数据资产化和服务复用,降低运营成本,支撑业务创新。受宏观经济影响,部分企业减少了对数据中台等…...
MySQL——数据表的基本操作(一)创建数据表
数据库创建成功后,就需要创建数据表。所谓创建数据表指的是在已存在的数据库中建立新表。需要注意的是,在操作数据表之前,应该使用 “ USE 数据库名 ” 指定操作是在哪个数据库中进行,否则会抛出 “ No database selected ” 错误。创建数据表…...
EPLAN EDZ 文件太大导入很慢如何解决?
目前各个品牌都在提供 EPLAN EDZ部件库文件,但是一般都是一个总的EDZ文件,导入过程中,因为电脑配置和其他问题,导致导入过程中EPLAN会崩溃或者长时间不动。 我们分析下EDZ文件的构成,这是个压缩文件,换了个壳而已。用压缩软件把edz打开,这里不是解压,直接右键,用解压…...
刷题——缺失的第一个正整数
缺失的第一个正整数_牛客题霸_牛客网 我选择了一个我比较能看懂的, int minNumberDisappeared(vector<int>& nums) {// write code heremap<int, int>hash;int n nums.size();//哈希表记录数组中出现的每个数字for(int i 0; i < n; i)hash[n…...
代理设置--一些库的代理设置
首先最好能获取一个免费代理,来继续下面的阅读和实验 也可以在本机设置代理,具体流程由于比较敏感,请自行搜索 代理设置成功后的测试网站是 http://www.httpbin.org/get , 访问该链接可以得到请求相关的信息,返回结果中的 ori…...
Debezium系列之:PostgreSQL数据库赋予账号数据采集权限的详细步骤
Debezium系列之:PostgreSQL数据库赋予账号数据采集权限的详细步骤 一、账号需要的权限二、创建账号,赋予登陆、复制权限三、赋予账号数据库权限四、赋予账号对表的权限五、创建PostgreSQL数据库复制组六、账号权限授予完整案例七、扩展——分区表设置八、扩展-撤销账号的权限…...
javascript:判断输入值是数字还是字母
1 代码示例 要判断输入值是数字还是字母,我们可以通过JavaScript获取输入框的值,然后使用isNaN函数来检查输入值是否为数字。 <!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title><s…...
Java-排序算法-复盘知识点
刷了24道简单排序题,18道中等排序题之后,给排序算法来个简单的复盘(从明天开始刷动态规划咯) 1.对于找多数元素(出现次数超过一半的元素)可以使用摩尔投票法。 2.HashSet的add方法非常实用:如…...
HarmonyOS 原生智能之语音识别实战
HarmonyOS 原生智能之语音识别实战 背景 公司很多业务场景使用到了语音识别功能,当时我们的语音团队自研了语音识别模型,方案是云端模型加端侧SDK交互,端侧负责做语音采集、VAD、opus编码,实时传输给云端,云端识别后…...
基于Gromacs的蛋白质与小分子配体相互作用模拟教程
在生命科学的广阔领域中,蛋白质与小分子配体之间的相互作用扮演着至关重要的角色。这些相互作用不仅影响着生物体内的各种生命活动,如信号传导、代谢调控和药物作用等,同时也是药物设计和开发的核心内容。因此,深入理解并模拟这些…...
Ubuntu下python3.12安装, 分布式 LLM 推理 exo 安装调试过程, 运行自己的 AI 集群
创作不易 只因热爱!! 热衷分享,一起成长! “你的鼓励就是我努力付出的动力” —调试有点废,文章有点长,希望大家用心看完,肯定能学废,感谢. 1. Ubuntu下python3.12安装 1.1 导入 Python 的稳定版 PPA,不用编译 sudo add-apt-repository ppa:deadsnakes/ppa sudo…...
pytest-bdd 行为驱动自动化测试
引言 pytest-bdd 是一个专为Python设计的行为驱动开发(BDD)测试框架,它允许开发人员使用自然语言(如Gherkin)来编写测试用例,从而使测试用例更易于理解和维护。 安装 通过pip安装 pip install pytest-b…...
PostgreSQL11 | 触发器
本文章代码已在pgsql11.22版本上运行且通过,展示页由pgAdmin8.4版本提供 上一篇总结了原著的第十章有关pgsql的视图的用法,本篇将总结pgsql的触发器的用法。 触发器 使用触发器可以自动化完成一些在插入数据或修改数据时,某些需要同期同步的…...
cesium canvas广告牌
在有些业务中,对场景中的广告牌样式要求比较高,需要动态显示一些数据,这个时候,我们可以通过将复杂背景样式制作成图片,通过canvas绘制图片和动态数据,从而达到比较好的显示效果。 1 CanvasMarker 类封装 …...
使用Floyd算法求解两点间最短距离
Floyd算法 Floyd算法又称为Floyd-Warshell算法,其实Warshell算法是离散数学中求传递闭包的算法,两者的思想是一致的。Floyd算法是求解多源最短路时通常选用的算法,经过一次算法即可求出任意两点之间的最短距离,并且可以处理有负权…...
[特殊字符] 智能合约中的数据是如何在区块链中保持一致的?
🧠 智能合约中的数据是如何在区块链中保持一致的? 为什么所有区块链节点都能得出相同结果?合约调用这么复杂,状态真能保持一致吗?本篇带你从底层视角理解“状态一致性”的真相。 一、智能合约的数据存储在哪里…...
Vue记事本应用实现教程
文章目录 1. 项目介绍2. 开发环境准备3. 设计应用界面4. 创建Vue实例和数据模型5. 实现记事本功能5.1 添加新记事项5.2 删除记事项5.3 清空所有记事 6. 添加样式7. 功能扩展:显示创建时间8. 功能扩展:记事项搜索9. 完整代码10. Vue知识点解析10.1 数据绑…...
云启出海,智联未来|阿里云网络「企业出海」系列客户沙龙上海站圆满落地
借阿里云中企出海大会的东风,以**「云启出海,智联未来|打造安全可靠的出海云网络引擎」为主题的阿里云企业出海客户沙龙云网络&安全专场于5.28日下午在上海顺利举办,现场吸引了来自携程、小红书、米哈游、哔哩哔哩、波克城市、…...
土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测;从基础到高级,涵盖ArcGIS数据处理、ENVI遥感解译与CLUE模型情景模拟等
🔍 土地利用/土地覆盖数据是生态、环境和气象等诸多领域模型的关键输入参数。通过遥感影像解译技术,可以精准获取历史或当前任何一个区域的土地利用/土地覆盖情况。这些数据不仅能够用于评估区域生态环境的变化趋势,还能有效评价重大生态工程…...
是否存在路径(FIFOBB算法)
题目描述 一个具有 n 个顶点e条边的无向图,该图顶点的编号依次为0到n-1且不存在顶点与自身相连的边。请使用FIFOBB算法编写程序,确定是否存在从顶点 source到顶点 destination的路径。 输入 第一行两个整数,分别表示n 和 e 的值(1…...
2025季度云服务器排行榜
在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...
免费PDF转图片工具
免费PDF转图片工具 一款简单易用的PDF转图片工具,可以将PDF文件快速转换为高质量PNG图片。无需安装复杂的软件,也不需要在线上传文件,保护您的隐私。 工具截图 主要特点 🚀 快速转换:本地转换,无需等待上…...
站群服务器的应用场景都有哪些?
站群服务器主要是为了多个网站的托管和管理所设计的,可以通过集中管理和高效资源的分配,来支持多个独立的网站同时运行,让每一个网站都可以分配到独立的IP地址,避免出现IP关联的风险,用户还可以通过控制面板进行管理功…...
MySQL 8.0 事务全面讲解
以下是一个结合两次回答的 MySQL 8.0 事务全面讲解,涵盖了事务的核心概念、操作示例、失败回滚、隔离级别、事务性 DDL 和 XA 事务等内容,并修正了查看隔离级别的命令。 MySQL 8.0 事务全面讲解 一、事务的核心概念(ACID) 事务是…...
相关类相关的可视化图像总结
目录 一、散点图 二、气泡图 三、相关图 四、热力图 五、二维密度图 六、多模态二维密度图 七、雷达图 八、桑基图 九、总结 一、散点图 特点 通过点的位置展示两个连续变量之间的关系,可直观判断线性相关、非线性相关或无相关关系,点的分布密…...
