首页
学习
活动
专区
圈层
工具
发布

C++ map和unordered_map详解

概述   C++中map和unordered_map提供的是一种键值对容器,在实际开发中会经常用到,它跟Python的字典很类似,所有的数据都是成对出现的,每一对中的第一个值称之为关键字(key),每个关键字只能在...map和unordered_map   map是一种有序的容器,底层是用红黑树实现的(什么是红黑树?)...unordered_map是一种无序的容器,底层是用哈希表实现的(哈希表-维基百科),哈希表最大的优点是把数据的查找和存储时间都大大降低。 直观对比 map unordered_map 优点 1....有序性,可应用于有顺序要求的应用中 2....  获取元素可以适用[]和at,如果我们索引的key并不在map对象里面,则 []会将这个key保存到map对象中,对应的value是该类型对应的初始化值; at会抛出异常 跟map用法也是一样的 Element

3.3K21
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【C++】哈希(unordered_set、unordered_map)

    unordered_map的使用 unordered_map也是无序的。 unordered_map是存储键值对的关联式容器,其允许通过keys快速的索引到与其对应的value。...在unordered_map中,键值通常用于惟一地标识元素,而映射值是一个对象,其内容与此键关联。键和映射值的类型可能不同。...在内部,unordered_map没有对按照任何特定的顺序排序, 为了能在常数范围内找到key所对应的value,unordered_map将相同哈希值的键值对放在相同的桶中。...unordered_map容器通过key访问单个元素要比map快,但它通常在遍历元素子集的范围迭 代方面效率较低。...上方是取string的第一个字符进行返回。同时也要手动传入这个仿函数。 这种取首字符的方法不是很好,下面是另一种字符串哈希算法: 该方法是遍历整个字符串,把ASCII码值全部加起来并返回。

    20310

    【C++】unordered_set 和 unordered_map 使用 | 封装

    set/map底层是红黑树 unordered_map/unordered_set 底层是 哈希表 ---- 红黑树是一种搜索二叉树,搜索二叉树又称为排序二叉树,所以迭代器遍历是有序的 而哈希表对应的迭代器遍历是无序的...---- 在map中存在rbegin以及rend的反向迭代器 ---- 在unordered_map中不存在rbegin以及rend的反向迭代器 ---- 1. unordered_set的使用...map统计时,会按照ASCII值排序 ---- 而unordered_map 中 元素是无序的 2....,使其调用哈希表中的begin和end 来实现 unordered_set的begin 和end unordered_map对于 begin和end的复用 在 unordered_map中使用哈希桶中的...HashTable的迭代器 来实现unordered_map的迭代器 ---- unordered_map中operator[]的实现 将insert的返回值 变为pair类型,第一个参数为迭代器

    45640

    Swisstable:C++中比std::unordered_map更快的hash表

    这个算法由google开源,最早在2017年的c++大会上分享过。...众所周知(我最喜欢问的面试题),解决hash冲突有以下经典的三种方式:开放地址法相邻地址法多散列函数法重点在于,std::unordered_map使用开放地址法来解决hash冲突。...把hash值分为高7位和低57位:低57位用于定位桶中slot的位置高7位用于在control byte中解决hash冲突control bytehash桶中每个slot对应一个1一个byte的控制字节...库Swiss Tables Design Notesc++语言实现,文档:Swiss Tables and absl::Hash把c++版本包装成c版本:(github)Accessing Abseil...Swiss Tables from C(github)Abseil - C++ Common Libraries源码C语言实现的版本:Swissmaprust语言的实现:hashbrown用代码生成的方法来提供

    2.4K30

    【C++】unordered_map和unordered_set的使用

    unordered就是无序的,unordered_map和unordered_set 是C++11之后才有的容器, 功能上和map/set基本相同,从底层看map和set是红黑树,unordered_map...set的详细介绍在: 【C++】set和multiset的常用接口详解 1.2 unordered_set和set的差异 查看⽂档我们会发现unordered_set的⽀持增删查且跟set的使⽤⼀模...其次set底层是红⿊树,红⿊树是⼆叉搜索树,⾛中序遍历是有序的,所以set迭代器遍历是有序+去重。⽽unordered_set底层是哈希表,迭代器遍历是⽆序+去重。...2.unordered_map系列 unordered_map和unordered_multimap的相关文档:unordered_map> - C++ Reference 前⾯部分我们已经学习了map...map的详细讲解在: 【C++】map和multimap的常用接口详解 unordered_map和map的差异就是unordered_set和set的那三个差异,差不多的。

    9700

    【C++深度探索】unordered_set、unordered_map封装

    ,来对C++STL库中的unordered_set和unordered_map进行模拟实现。...在内部,unordered_map没有对按照任何特定的顺序排序, 为了能在常数范围内找到key所对应的value,unordered_map将相同哈希值的键值对放在相同的桶中。...unordered_map容器通过key访问单个元素要比map快,但它通常在遍历元素子集的范围迭代方面效率较低。...unordered_map和map核心功能重复90%,它们区别在于: 对键值对中key要求不同: map:key要支持比较大小 unordered_map:key要支持转换成整型+比较相等 map遍历有序...,unordered_map遍历无序 map有双向迭代器,unordered_map单向迭代器 它们之间性能有差异 unordered_map常见接口: 函数声明 功能介绍 unordered_map(

    23610

    【C++】unordered_set和unordered_map的封装(哈希)

    今日更新了unordered_map和unordered_set封装的相关内容 欢迎大家关注点赞收藏⭐️留言 key和pair 前面已经实现了哈希的底层,现用哈希进行封装。...unordered_set和unordered_map的封装和map、set大体思路一样。...hash是底层,他并不知道传入的是k还是pair,但是上层的unordered_set和unordered_map知道。...仿函数hash 由于hash现在是底层,我们的仿函数不可能直接传给hash底层,所以得在unordered_set和unordered_map上传多一个模板参数,这样取模的仿函数就可以在外面传了。...迭代器 当遍历完一个桶后,准备找下一个桶时,就需要有哈希表,不然就找不到下一个桶,所以iterator需要传第二个参数:哈希表的指针。

    20610

    【C++】unordered_map和unordered_set的使用 及 OJ练习

    所以,map和set我们用迭代器遍历,得到的是有序的序列,二unordered系列,我们去遍历的话,得到的是无序的。 其实单从使用上来说最大的区别就是这个。...另外我们会注意到它的迭代器没有rbegin、rend,因为它的迭代器是单向的嘛,都不支持反向遍历。...当然也可以用迭代器遍历。...然后,我们遍历其中一个数组,遍历的同时去依次判断当前元素在不在另一个数组中,如果在,就是交集。...然后遍历第二个数组,依次取每个元素判断其是否在map中存在等效键(用count接口),如果存在就是交集,放入vector里面并让其对应的次数–,如果次数减到0了,就从map中删除掉,因为此时它的个数已经等于它在两数组中出现次数的较小值了

    48210

    【C++】开散列实现unordered_map与unordered_set的封装

    本文主要介绍unordered_map与unordered_set的封装,此次封装主要用上文所说到的开散列,通过开散列的一些改造来实现unordered_map与unordered_set的封装 一、...模板参数 由于unordered_set 是 K 模型的容器,而 unordered_map 是 KV 模型的容器,所以需要对结点的参数进行改造,unordered_set可以使用,unordered_map...,并没有反向迭代器,所以没有实现–-运算符的重载,若是想让哈希表支持双向遍历,可以考虑将哈希桶中存储的单链表结构换为双链表结构。...,哈希表的 const 迭代器不能复用普通迭代器的代码,我们查看源码: 这与我们之前所复用的不同,上面stl源码中可以看到并没有用以前的复用: 这是因为如果使用const版本,那么_tables使用[...在析构哈希表时我们只需要遍历取出非空的哈希桶,遍历哈希桶当中的结点并进行释放即可 ~HashTable() { for (size_t i = 0; i < _tables.size();

    30820

    【C++高阶】哈希的应用(封装unordered_map和unordered_set)

    前言 哈希类的实现参考上一篇文章:【C++高阶】哈希函数底层原理全面探索和深度解析-CSDN博客 之前我们已经学习了如何手搓哈希,现在让我们来对哈希进行改造,并且封装成unordered_map和unordered_set...尽管如此,它们在底层数据结构(如HashTable)的实现上有很多相似之处 改造内容如下: K:key的类型 T:如果是unordered_map,则为pair; 如果是unordered_set...其他功能的实现 private: vector _tables; //指针数组,数组的每个位置存的是指针 size_t _n; //表中存储数据个数 }; 2....哈希的迭代器 2.1 迭代器基本设计 // 为了实现简单,在哈希桶的迭代器类中需要用到hashBucket本身,所以我们要进行一下前置声明,并且我们在 HashTable 中也要设置一个友元(friend...Unordered_Map的模拟实现 5.1 Unordered_Map的设计 template> class unordered_map

    23210

    【C++】使用哈希表模拟实现STL中的unordered_set和unordered_map

    所以这里有些地方我们就不会特别清楚的去说明了,如果某些地方大家看的不能太明白,建议先搞懂这篇文章——使用红黑树模拟实现STL中的map与set 这里面我们是讲的比较清楚的。...哈希表迭代器的实现 接着我们来实现一下哈希表的迭代器 我们来思考一下它的迭代器应该怎么搞: 那按照我们以往的经验,它的迭代器应该还是对结点指针的封装,然后顺着每个不为空的哈希桶(链表)进行遍历就行了。...比如走到1002这个结点 如果node->next为空,就说明当前这个桶遍历完了,所以就往后寻找下一个不为空的桶,然后it指向这个桶的第一个结点。 库里面其实也是这样搞的。...所以,对于哈希表的迭代器来说,还是结点指针的封装,但是还要包含另一个成员即哈希表。 因为我们遍历哈希表去依次找桶。...当插入成功的时候,pair的first为指向新插入元素的迭代器,second为true,当插入失败的时候(其实就是插入的键已经存在了),那它的first为容器中已存在的那个相同的等效键元素的迭代器,second

    40210

    踏入 C++ 的深邃世界:实现 unordered_set 与 unordered_map 的优雅之旅

    前言 在 C++ 标准库中,unordered_set 和 unordered_map 是常用的哈希容器,分别用于存储唯一元素集合和键值对关联表。...本篇文章将详细讲解如何使用 C++ 模板实现 HashTable 类,并基于该类构建 unordered_set 和 unordered_map,同时深入分析每个成员函数及其实现细节。...尽管如此,它们在底层数据结构(如HashTable)的实现上有很多相似之处。...begin 和 end: begin 和 end 返回容器的起始和结束迭代器,用于遍历 unordered_map 的所有键值对。...结语 通过实现 HashTable 以及基于它构建 unordered_set 和 unordered_map,我们不仅深入了解了哈希表的基本操作和冲突解决方法,还学习了如何使用 C++ 模板和仿函数来设计通用数据结构

    30510

    C++容器进阶:深入解析unordered_map与unordered_set的前世今生

    引言:现代C++容器的王者 在C++的浩瀚星空中,unordered_map和unordered_set就像两颗璀璨的明珠,它们revolutionize了我们处理关联容器的方式。...学习路径 理解哈希表的内部机制 掌握unordered_map和unordered_set的使用 深入探索它们的性能特征 实战项目实践 第一章:哈希表的数学魔法(C++) 1.1...的深度解析 2.1 unordered_map的设计哲学 unordered_map是基于哈希表实现的关联容器,具有以下特点: 键值对存储 平均O(1)的查找、插入和删除 不保证元素顺序...和unordered_set不仅仅是容器,更是现代C++编程中的瑰宝。...它们体现了计算机科学中高效、灵活的设计哲学。愿每一位读者都能在探索的旅程中,找到属于自己的编程之美!

    21410
    领券