探索哈希表: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算法是求解多源最短路时通常选用的算法,经过一次算法即可求出任意两点之间的最短距离,并且可以处理有负权…...
基于算法竞赛的c++编程(28)结构体的进阶应用
结构体的嵌套与复杂数据组织 在C中,结构体可以嵌套使用,形成更复杂的数据结构。例如,可以通过嵌套结构体描述多层级数据关系: struct Address {string city;string street;int zipCode; };struct Employee {string name;int id;…...
在软件开发中正确使用MySQL日期时间类型的深度解析
在日常软件开发场景中,时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志,到供应链系统的物流节点时间戳,时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库,其日期时间类型的…...
反向工程与模型迁移:打造未来商品详情API的可持续创新体系
在电商行业蓬勃发展的当下,商品详情API作为连接电商平台与开发者、商家及用户的关键纽带,其重要性日益凸显。传统商品详情API主要聚焦于商品基本信息(如名称、价格、库存等)的获取与展示,已难以满足市场对个性化、智能…...
c++ 面试题(1)-----深度优先搜索(DFS)实现
操作系统:ubuntu22.04 IDE:Visual Studio Code 编程语言:C11 题目描述 地上有一个 m 行 n 列的方格,从坐标 [0,0] 起始。一个机器人可以从某一格移动到上下左右四个格子,但不能进入行坐标和列坐标的数位之和大于 k 的格子。 例…...
【开发技术】.Net使用FFmpeg视频特定帧上绘制内容
目录 一、目的 二、解决方案 2.1 什么是FFmpeg 2.2 FFmpeg主要功能 2.3 使用Xabe.FFmpeg调用FFmpeg功能 2.4 使用 FFmpeg 的 drawbox 滤镜来绘制 ROI 三、总结 一、目的 当前市场上有很多目标检测智能识别的相关算法,当前调用一个医疗行业的AI识别算法后返回…...
使用 SymPy 进行向量和矩阵的高级操作
在科学计算和工程领域,向量和矩阵操作是解决问题的核心技能之一。Python 的 SymPy 库提供了强大的符号计算功能,能够高效地处理向量和矩阵的各种操作。本文将深入探讨如何使用 SymPy 进行向量和矩阵的创建、合并以及维度拓展等操作,并通过具体…...
关键领域软件测试的突围之路:如何破解安全与效率的平衡难题
在数字化浪潮席卷全球的今天,软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件,这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下,实现高效测试与快速迭代?这一命题正考验着…...
安宝特方案丨船舶智造的“AR+AI+作业标准化管理解决方案”(装配)
船舶制造装配管理现状:装配工作依赖人工经验,装配工人凭借长期实践积累的操作技巧完成零部件组装。企业通常制定了装配作业指导书,但在实际执行中,工人对指导书的理解和遵循程度参差不齐。 船舶装配过程中的挑战与需求 挑战 (1…...
uni-app学习笔记三十五--扩展组件的安装和使用
由于内置组件不能满足日常开发需要,uniapp官方也提供了众多的扩展组件供我们使用。由于不是内置组件,需要安装才能使用。 一、安装扩展插件 安装方法: 1.访问uniapp官方文档组件部分:组件使用的入门教程 | uni-app官网 点击左侧…...
电脑桌面太单调,用Python写一个桌面小宠物应用。
下面是一个使用Python创建的简单桌面小宠物应用。这个小宠物会在桌面上游荡,可以响应鼠标点击,并且有简单的动画效果。 import tkinter as tk import random import time from PIL import Image, ImageTk import os import sysclass DesktopPet:def __i…...
