首页
Python
Java
前端
数据库
Linux
Chatgpt专题
开发者工具箱
unordered专题
C++数据结构重要知识点(5)(哈希表、unordered_map和unordered_set封装)
1.哈希思想和哈希表 (1)哈希思想和哈希表的区别 哈希(散列、hash)是一种映射思想,本质上是值和值建立映射关系,key-value就使用了这种思想。哈希表(散列表,数据结构),主要功能是值和存储位置建立映射关系,它通过key-value模型中的key来定位数组的下标,将value存进该位置。 哈希思想和哈希表数据结构这两个概念要分清,哈希是哈希表的核心思想。 (2)unordered
阅读更多...
【C++STL(十四)】一个哈希桶简单模拟实现unordered_map/set
目录 前言 一、改造哈希桶 改造结点类 改造主体 模板参数改造 迭代器(重点) 改造完整哈希桶 unordered_map模拟实现 unordered_set模拟实现 前言 前面的文章都有说unordered_map/set的底层结构就是哈希表,严格来说是哈希桶,那么接下来我们就尝试使用同一个哈希桶来模拟实现一下。整体的逻辑和一棵红黑树封装map/set类似,所以
阅读更多...
详解map、multimap、unordered_map、unordered_multimap
详解map、multimap、unordered_map、unordered_multimap 相信有不少同学和我一样刚接触C++ STL,被其深深吸引。但是想弄懂每个模板类不是一个容易事。大家应该对vector、list、stack、queue等类比较了解了,所以今天详细介绍下几个很常用很强大但有点不太好懂的类map、multimap、unordered_map、unordered_m
阅读更多...
c++ unordered_set的count方法
在 C++ 的 std::unordered_set 中,count 方法用于返回集合中与指定值相等的元素的数量。由于 unordered_set 的特性是只允许唯一元素,因此对于任何给定元素,count 方法的返回值只能是 0 或 1。 语法 size_t count(const Key& key) const; key: 要查找的元素。返回值: 如果集合中存在这个元素,返回 1;如果不
阅读更多...
【C++】unordered_set 容器的最全解析(什么是unordered_set?unordered_set的常用接口有那些?)
目录 一、前言 二、预备知识 💢关联式容器💢 💢键值对💢 💢哈希结构的关联式容器💢 三、unordered_set 详解 🔥unordered_set 的介绍 🔥unordered_set 的构造 🔥unordered_set 的使用 🥝 insert 🍇find 🍍 erase 🍉size 🍋empty 🍓
阅读更多...
【C++STL详解(十三)】unordered系列容器的介绍与使用
目录 前言 一、unordered_map 介绍 使用 构造方式 修改 容量 迭代器 元素访问 查询 桶操作 二、unordered_set 介绍 使用 构造 修改 容量 迭代器(只有单向) 查询 桶操作 三、unordered系列的性能测试 前言 前面提到的map/set是C++98提供的关联式容器,底层结构是红黑树,最差情况下需
阅读更多...
【C++ 第十七章】封装 unordered_map / unordered_set
声明:上一章讲解了 哈希结构的原理与实现,本章主要将上一章学过的拉链法的哈希结构封装进 unordered_map / unordered_set,所以需要先学过相关知识,才能更好吸收本章知识 上一章的链接:【C++ 第十六章】哈希 1. unordered_map / unordered_set 的 基本结构 之前封装 map 和 set 时,因为 map 的数
阅读更多...
模拟实现STL中的unordered_map和unordered_set
目录 1.unordered_map和unordered_set简介 2.unordered_map和unordered_set设计图 3.迭代器的设计 4.哈希表的设计 5.my_unordered_map和my_unordered_set代码 1.unordered_map和unordered_set简介 unordered_map和unordered_set的使用非常类似于ma
阅读更多...
STL--unordered_set和unordered_map的模拟实现
1.unordered系列关联式容器 在C++98中,STL提供了底层为红黑树结构的一系列关联式容器,在查询时效率可达到,即最差情况下需要比较红黑树的高度次,当树中的节点非常多时,查询效率也不理想。最好的查询是,进行很少的比较次数就能够将元素找到,在C++11中,STL又提供了4个unordered系列的关联式容器:unordered_map、unordered_set、unordered_mu
阅读更多...
std::unordered_map主键为结构体
std::unordered_map为hashmap,如果直接使用结构体作为key值,编译时会报错,需要自己定义结构体的hash值的计算方法。 // 自定义结构体struct MyStruct {size_t handle;size_t getHashValue() {return handle;}}// 定义结构体的hash值计算方法template<>struct std::hash
阅读更多...
加强理解 unordered_map (面向竞赛)
目录 基本概念 构造函数和成员函数 主要成员函数 应用场景 1. 快速查找需求 2. 高效键值对映射 3. 动态插入与删除 4. 无序数据集合 5. 大规模数据处理 6. 频繁存在查找失败的情况 7. 空间换时间策略 8. 哈希冲突的优化处理 在C++中,unordered_map 是一个基于哈希表实现的关联容器,它存储键值对,并通过一个哈希函数将键映射到存储桶。
阅读更多...
C++第四十弹---从零开始:模拟实现C++中的unordered_set与unordered_map
✨个人主页: 熬夜学编程的小林 💗系列专栏: 【C语言详解】 【数据结构详解】【C++详解】 目录 1 哈希概念 2 哈希冲突 3 哈希函数 4 哈希冲突解决 4.1 闭散列 4.1.1. 线性探测 4.1.2. 二次探测 4.2 开散列 4.2.1. 开散列概念 4.2.2. 开散列实现 4.2.3. 开散列增容 4.2.4. 开散列的思考 4.2.5. 开散列
阅读更多...
从零开始手写STL库:unordered_set
从零开始手写STL库–unordered_set的实现 Gihub链接:miniSTL 文章目录 从零开始手写STL库–unordered_set的实现一、unordered_set是什么二、unordered_set要包含什么函数总结 一、unordered_set是什么 在STL中,std::unordered_set 是一个无序关联容器,其内部基于哈希表实现。
阅读更多...
【C++11 之新增容器 array、foward_list、tuple、unordered_(multi)map/set】应知应会
C++11 标准中新增了多个容器,这些容器为 C++ 程序员提供了更多的选择,以满足不同的编程需求。以下是对这些新容器的介绍和使用案例: std::array 介绍: std::array 是一个固定大小的数组容器,它在栈上分配内存,并提供了类似于标准库容器的接口。它提供了更好的类型安全性和范围检查,同时保持了与原生数组相似的性能。std::array 的大小必须在编译时确定,并且不能更改。
阅读更多...
C++ 关联容器使用 map, unordered_map, set, unordered_set, multiset, unordered_multiset
关联容器是否有序是否关联值是否可重复访问时间set是否否对数map是是否对数multiset是否是对数multimap是是是对数unordered_map否是否常数unordered_set否否否常数unordered_multiset否否是常数unordered_multimap否是是常数 #include <map>#include <set>#i
阅读更多...
C++——unordered_map讲解
文章目录 unordered_map讲解1. 引入头文件2. 基本概念3. 声明和初始化4. 基本操作插入元素访问元素删除元素查找元素迭代器 5. 注意事项6. 总结 unordered_map讲解 <unordered_map> 是 C++ 标准库中的一个头文件,提供了哈希表的实现,即无序关联容器。std::unordered_map 是一种关联容器,它使用哈希表来存储键值
阅读更多...
C++中map,hash_map,unordered_map,unordered_set区别与联系
一、hash_map、unordered_map 这两个的内部结构都是采用哈希表来实现。区别在哪里?unordered_map在C++11的时候被引入标准库了,而hash_map没有,所以建议还是使用unordered_map比较好。 哈希表的好处是什么?查询平均时间是O(1)。顾名思义,unordered,就是无序了。无序容器在存储上组织为一组桶,每个桶保存零个或多个元素。无序容器使用一个哈
阅读更多...
离散化——unordered_map
学习一下unordered_map的用法,上海区域赛前才第一次见这个东西,看到和map用法一样自信觉得能用,然而场上卡住了,现在滚过来学一下orz【虽然事后发现G题根本不需要用这个东西。 学过哈希的都很容易理解离散化,无非就是数据过大开不了那么大的数组时,但其实中间有很多浪费掉的空间,那么映射到另一个数组中就可以了。 以前常用的c++离散化是 // a[i] 为初始数组,下标范围为 [1,
阅读更多...
C++|哈希结构封装unordered_set和unordered_map
上一篇章,学习了unordered系列容器的使用,以及哈希结构,那么这一篇章将通过哈希结构来封装unordered系列容器,来进一步的学习他们的使用以及理解为何是如此使用。其实,哈希表的封装方式和红黑树的封装方式形式上是差不多的,如果有了红黑树的封装理解经验,我相信在理解哈希封装的过程会减少负担的。当然,在使用哈希结构中采用的是更具代表的哈希桶,接下来进行封装。 一、改造哈希表 1.1模
阅读更多...
c++|unordered系列关联式容器(unordered_set、unordered_map介绍使用+哈希结构)
目录 一、unordered_set的介绍与使用 1.1unordered_set介绍 1.2unordered_set使用 2.2.1构造 2.2.2容量 2.2.3修改 二、unordered_map的介绍与使用 2.1unordered_map介绍 2.2unordered_map使用 2.2.1构造 2.2.2容量 2.2.3修改 三、底层结构
阅读更多...
c++ 哈希 unordered_map unordered_set 的学习
1. unordered 系列 在 c++98 中, STL 提供了底层是红黑树结构的一系列关联式容器,set 和 map 的查询效率可以达到 log2N,红黑树最差的情况也只是需要比较红黑树的高度次,当节点数量非常多时,查找一个节点还需要比较几十次,效果也不是太理想,最理想的查询是,进行很少次的比较次数就能将元素找到。 因此在 c++11 中,STL 又提供了 unordered 系列,uno
阅读更多...
Linux下map hash_map和unordered_map效率比较
原理介绍 map介绍 Map是STL[1]的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时候,在编程上提供快速通道。这里说下map内部数据的组织,map内部自建一颗红黑树(一种非严格意义上的平衡二叉树),这颗树具有对数据自动排序的功能,所以在map内部所
阅读更多...
c++中 unordered_map 与 unordered_set 用法指南
unordered_map 与 unordered_set 区别与联系 unordered_map 和 unordered_set 都是 C++ 标准模板库(STL)中的容器,它们使用哈希表作为底层数据结构,提供了快速的查找、插入和删除操作。下面是它们之间的联系与区别: 联系 底层实现:两者都基于哈希表实现,利用了哈希函数来分布元素。性能特点:它们都提供平均时间复杂度为 O(1) 的查找、插入
阅读更多...
C++容器之无序映射(std::unordered_map)
目录 1 概述2 使用实例3 接口使用3.1 construct3.2 assigns3.3 iterators3.4 capacity3.5 access3.6 find/count/equal_range3.7 emplace3.8 emplace_hint3.9 insert3.10 erase3.11 clear3.12 swap3.13 bucket_count3.14 max_b
阅读更多...
STL库 —— unordered_set与unordered_map的封装
这里要对 unordered_set 与 unordered_map 进行封装,封装时使用的是上一篇中学的 HashBucket 。不仅要完成封装,同时要写入迭代器。 一、HashBucket 的修改 1.1 节点的修改 T 首先来认识一下使用 unordered_set 和 ordered_map 时的区别: unordered_set 存储唯一的键值。你只需要传入要插入的值。 #in
阅读更多...
unordered_mapset
文章目录 Ⅰ. 使用a. unordered_mapb. unordered_set Ⅱ. 哈希表a. 闭散列:线性探测1.仿函数,2.插入,3.删除,4.查找,5.扩容 b. 开散列:哈希桶1.仿函数,2.插入,3.删除,4.查找,5.扩容 Ⅲ. 封装实现a. HashTable的封装完善b. unordered_setc. unordered_map 前言:unordered
阅读更多...