c++的hashmap及底层实现

文章目录

  • 什么是hashmap
  • hash碰撞
  • hash常见结构

什么是hashmap

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

hash碰撞

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

hash常见结构

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

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

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

你可能感兴趣的:(c++,算法)