hash表的使用

我们先了解hash表的存储方式。哈希方法中使用的转换函数称为哈希(散列)函数,构造出来的结构称为哈希表(Hash Table)(或者称散列表)。他就类似于,创建一个数组,然后把元素插入到数组中,但这里是用键值对来进行存储,同时这里的key值必须要支持==操作,还有要可以取模或者用一个仿函数来支持它可以进行转整形取模。

下面是哈希表中常用的两种存储方法。

接下来就是使用hash表。

#include<unordered_map> //头文件

unordered_map<int, int> map;//定义

初始化 

unordered_map<int, int> map{ {1,1},{2,2},{3,3} };//通过key,value创建
//如果知道要创建的哈希表的元素个数时,也可以在初始化列表中指定元素个数
unordered_map<int, int> map{ {{1,1},{2,2},{3,3}},3 };//这里的3就是元素个数

插入 

it = hmap.find(2);//这里it为迭代器,那么这里就是查找的方式
map[4]=2;//还可以通过下标[]的方法进行修改和插入,  👆查找+修改呗
map.insert({ 5,15 });
map.insert({ 5,16 });//因为插入一次之后,key=5的位置已经有了元素,那么第二次就会失败

  • 10
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值