c++的hashmap及底层实现

什么是hashmap

哈希表是根据关键码的值而直接进行访问的数据结构,例如数组。一般哈希表都是用来快速判断一个元素是否出现集合里,
时间复杂度为O(1)。

hash碰撞

如果两个元素都映射到了同一索引下表 的位置,这一现象叫做哈希碰撞。
解决办法:1.拉成链式结构;2.找下一个空位,前提哈希表还有位置。

hash常见结构

数组
set (集合)
map(映射)

在这里插入图片描述
可以这样记:底层实现为红黑树的一定是有序的且不可更改数值,改了以后整棵树就错乱了,底层实现为hashmap的一定无序。multi的是数值可以重复的。
在这里插入图片描述
当我们要使用集合来解决哈希问题的时候,优先使用unordered_set,因为它的查询和增删效率是最优的,如果需要集合是有序的,那么就用set,如果要求不仅有序还要有重复数据的话,那么就用multiset。

那么再来看一下map ,在map 是一个<key ,value> 的数据结构,map中,对key是有限制,对value没有限制的,因为key的存储方式使用红黑树来实现的。哈希法也是牺牲了空间换取了时间,因为我们要使用额外的数组,set或者是map来存放数据,才能实现快速的查找。

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值