首页 > 编程语言 >C++哈希表

C++哈希表

时间:2024-12-13 20:31:17浏览次数:7  
标签:std 元素 C++ 键值 hashTable 哈希 unordered

哈希表教程

目录

  1. 哈希表是什么
  2. 怎么用哈希表
  3. 插入键值对
  4. 查找元素
  5. 删除元素
  6. 遍历哈希表
  7. count检查是否存在某个键

怎么用哈希表

1.包含头文件
首先,你需要包含 unordered_map 的头文件:

#include<unordered_map>

2.创建哈希表

std::unordered_map<KeyType,ValueType>hashTable

KeyType是键的类型,ValueType是值的类型
例:如果想存储 键:字符串,值:整数

std::unordered_map<std::string,int>hashTable

前面如果写了 using namespace std; ,这里可以不用写std::

插入键值对

用 insert 方法或 [] 操作符来插入键值对:

//用insert方法
hsahTable.insert(std::make_pair("apple",1));

//用[]操作符,如果键不存在,会自动创建一个键
hashTable["banana"]=2;
//hashTable["键"]=值;

查找元素

用 find 方法或 [] 操作符来查找元素:

//1.find方法
auto it=hashTable.find("apple");
//auto:计算机会根据返回的情况确定类型
//找到返回,不等于哈希表的最后一个说明找到了
if(it!=hashTable.end()){
	std::cout<<"Found"<<it->second<<std::endl;
	//it->second为apple键对应的值,std::endl为输出换行
}else{
//找到最后没找到
	std::cout<<"Not found"<<std::endl;
}

//用[]操作符,如果键不存在,返回默认值0
//如果键存在,返回值
int value=hashTable["cherry"];

删除元素

用erase方法删除

//删除键为“banana”的元素
hashTable.erase("banana");

遍历哈希表

for(auto it=hashTable.begin();it!=hashTable.end();++it){
	std::cout<<it->first<<"->"<<it->sceond<<std::endl;
}
//从哈希表的开始到哈希表的结束,每次+1
//it->first为键,it->second为值

count检查是否存在某个键

作用:

  • 如果键存在,返回1
  • 如果键不存在,返回0;
    来找哈希表里是否有特定的键

例:

//声明哈希表,键的类型为int,值的类型为字符串
std::unordered_map<int,std::string>hashTable;

//插入一些键值对
hashTable[1]="one";
hashTable[2]="two";

//检查键是否存在
if(hashTable.count(1)>0){
//返回1,说明找到了
	std::cout<<"键1在哈希表里有"<<std::endl;
}else{
	std::cout<<"键1不在哈希表里"<<std::endl;
}

标签:std,元素,C++,键值,hashTable,哈希,unordered
From: https://blog.csdn.net/qq_52291558/article/details/144458789

相关文章

  • 【算法】【优选算法】哈希表
    目录一、简介二、两数之和三、⾯试题01.02.判定是否互为字符重排四、217.存在重复元素五、219.存在重复元素II六、49.字⺟异位词分组一、简介哈希表就是一个使用键值对key-value来存储数据的容器。用于快速查找某个元素O(1)时间复杂度。应用场景:频繁查找元素......
  • 在CodeBolcks+Windows API下的C++编程教程——给你的项目中添加资源文件和图标
    0.前言我想通过编写一个完整的游戏程序方式引导读者体验程序设计的全过程。我将采用多种方式编写具有相同效果的应用程序,并通过不同方式形成的代码和实现方法的对比来理解程序开发更深层的知识。了解我编写教程的思路,请参阅体现我最初想法的那篇文章中的“1.编程计划”:学习编程......
  • C++ 计算日期差
     #include<iostream>usingnamespacestd;//定义日期结构体,用于存放年、月、日这三个日期相关的信息structDate{intyear;intmonth;intday;};intmain(){Dated1,d2;//从标准输入(控制台)读取第一个日期的年、月、日信息cin>>d......
  • 深入计算机语言之C++:STL之list的模拟实现
    ......
  • C++_快慢指针在业务开发中的应用-数据结构与算法
    报错的解决vector不是模板问题,第一是由于没有添加#include<vector>。第二是需要添加命名空间。命名空间添加有两种,第一是直接在vector前面加上std::,第二是开头加入usingnamespacestd;加入vector后,std命名空间没有vector的问题--C++版本问题其他快慢下标......
  • 9、C++继承
    1、继承1.1、认识继承继承一般发生在家族图谱、动植物分类等,注意关系要合理比如:        学生:姓名 年龄 身高 学生编号                  吃饭 睡觉 学习         老师:姓名 年龄 身高 教师编号          ......
  • c++类详解
    学习转自:c++类详解-CSDN博客1#include<iostream>2usingnamespacestd;34classCircle{5private:6doubleradius;78public:9//构造函数10Circle(doubler){11radius=r;12}1314//计算面积15doub......
  • 【C++】AVL树
    AVL树概念AVL树是最先发明的⾃平衡⼆叉查找树,AVL是⼀颗空树,或者具备下列性质的⼆叉搜索树:它的左右⼦树都是AVL树,且左右⼦树的⾼度差的绝对值不超过1。AVL树是⼀颗⾼度平衡搜索⼆叉树,通过控制⾼度差去控制平衡。AVL树得名于它的发明者G.M.Adelson-Velsky和E.M.Landis是......
  • C++中多态性在实际项目中的应用场景有哪些?
    一、图形绘制系统:在一个图形绘制系统中,可以定义一个抽象的图形类,然后派生出各种具体的图形类,如圆形、矩形、三角形等。通过多态性,可以使用一个统一的接口来绘制不同类型的图形,而不需要为每种图形都编写单独的绘制函数。二、游戏开发在游戏开发中,不同的游戏角色可能有不同的......
  • 关于数据隐藏:为什么要进行数据隐藏?如何在C++中实现数据隐藏?以及数据隐藏对面向对象编
    一、为什么要进行数据隐藏?数据隐藏可以提高程序的安全性和可维护性。可以将数据成员声明为私有或受保护,可以防止外部代码直接访问和修改这些数据,从而减少错误的发生。同时,数据隐藏也使得类的内部实现细节对外部不可见,这样在修改类的内部实现时,不会影响外部代码的使用。二、......