首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

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

使用 unordered_map官方文档 ---- unordered_set 官方文档 ---- set / map与unordered_set / unordered_map 使用功能基本相同,但是两者的底层结构不同...头文件,在其中创建命名空间unordered_setunordered_set中实现一个仿函数, unordered_set 的第二个参数 为 K unordered_set作为 K 模型 ,所以...对于 begin和end的复用 在unordered_set中,使用哈希桶中的HashTable的迭代器 来实现unordered_set的迭代器 加入typename 是因为编译器无法识别HashBucket...修改迭代器数据 问题 在unordered_set中,借助 哈希桶中的普通迭代器 实现 unordered_set的普通迭代器 在unordered_set中,借助 哈希桶中的const迭代器 实现...unordered_set的const迭代器 ---- 在STL中,是不允许 unordered_set去 *it 修改数据的 ,但是在自己实现的迭代器中却可以通过 ---- 在STL中将 unordered_set

24840

【C++】哈希表封装实现 unordered_map 和 unordered_set

unordered_set 的介绍 unordered_set 和 unordered_map 的区别再于 unordered_set 是 K模型 的容器,而 unordered_map 是 KV模型...unordered_set 和 unordered_map 的功能与要求基本一样: unordered_set 的查询效率为 O(1); unordered_set 遍历得到序列的元素顺序是不确定的;...unordered_set 的底层结构为开散列的哈希表; unordered_set 对 key 的要求是能够转换为整形。...与 unordered_map 为数不多的不同的地方在于,unordered_set 不需要修改 value,所以也就不支持 operator[] 函数; unordered_set 的接口 unordered_set...同时,unordered_set insert 函数的返回值变为 pair 后又会引发普通迭代器赋值给 const 迭代器的问题,所以对于 unordered_set

1.1K30

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

本文主要介绍unordered_map与unordered_set的封装,此次封装主要用上文所说到的开散列,通过开散列的一些改造来实现unordered_map与unordered_set的封装 一、...模板参数 由于unordered_set 是 K 模型的容器,而 unordered_map 是 KV 模型的容器,所以需要对结点的参数进行改造,unordered_set可以使用,unordered_map...如果是unordered_map容器,那么它传入底层哈希表的模板参数就是Key和Key和Value构成的键值对,如果是unordered_set容器,那么它传入底层哈希表的模板参数就是Key和Key...{ private: buckethash::HashTable _ht; }; 如此就可以实现泛型了,如果是unordered_set...而data既可以是unordered_set的,也可以是unordered_map的,所以我们需要仿函数来实现不同容器所对应的需求,然后传入: unordered_map返回kv.first template

15320

【C++】开散列哈希表封装实现unordered_map和unordered_set

,只是 其底层结构不同,他们不再以红黑树作为底层结构,而是以挂哈希桶的哈希表作为底层结构,就是用存储结点指针的vector来实现哈希表,哈希表的每个位置是一个桶,桶结构是一个存储value的单链表,unordered_set...哈希最大的作用就是查找,如果你想进行排序什么的,哈希迭代器遍历的结果是无序的,只有map和set遍历的结果才是有序的,所以哈希并不具有排序的功能,unordered_map和unordered_set仅仅只有去重的功能而已...开散列的哈希表是最常用的方式,库里面的unordered_map和unordered_set用的也是哈希桶的方式实现的,我们模拟实现的哈希桶也仿照库实现,哈希结点node里面存储键值对和下一个结点指针。...但是哈希表的迭代器却没有通过增加模板参数来解决,而是重写了一个struct __hashtable_const_iterator { }类,以这样的方式来实现unordered_map和unordered_set

1.6K30

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

前言 前面的文章我们学习了unordered_set和unordered_map的使用以及哈希表,并且我们提到了unordered_set和unordered_map的底层结构其实就是哈希表。...增加一个模板参数 2. unordered_set和unordered_map增加KeyOfT仿函数 然后我们把unordered_set/map能写的先写一写: 3. insert封装及测试 那我们先把...然后end用空构造就行了 6. unordered_set和unordered_map的迭代器封装 那哈希表的迭代器实现好,我们就可以封装unordered_set和unordered_map的迭代器了...先来unordered_set: 来试一下 报了好多错误。...10. const迭代器的实现及unordered_set元素可以修改问题的解决 还有一个问题就是我们的unordered_set里面的元素现在是可以修改的,但是正常情况key是不能修改的,而且他是哈希函数里面的操作数

10910

python set大小_python set集合

集合set 可变的 无序的 不重复的元素集合 set定义 初始化 set() 生成一个空集合 set(iterable) 可通过可迭代对象生产一个新的集合 s1 =set() s2= set(range...(5)) s3= set(list(range(10))) s4= {} #这是字典的定义方法 s5 = {9,10,11} #set s6 = {(1,2),3,’a’} s7= {[1],(1,),...1} #set的元素要求必须可以hash 列表不能hash set的元素要求必须可以hash 目前学过的不可hash的类型有list、set 元素不可以索引 set可以迭代 set增加 add(elem...) 增加一个元素到set中 如果元素存在,什么都不做 update(*others) 合并其他元素到set元素中来 参数others必须是可迭代对象 就地修改 set删除 remove(elem) 从set...< set2 判断set1是否是set2的真子集 issuperset(other)、>= 判断当前集合是否是other的超集 set1 > set2 判断set1是否是set的真超集 isdisjoint

98720

python set大小_python set集合

参考链接: Python 集合set remove() 集合set  可变的  无序的  不重复的元素集合  set定义 初始化  set() 生成一个空集合  set(iterable) 可通过可迭代对象生产一个新的集合... s1 =set()  s2= set(range(5))  s3= set(list(range(10)))  s4= {} #这是字典的定义方法  s5 = {9,10,11} #set  s6...= {(1,2),3,'a'}  s7= {[1],(1,),1} #set的元素要求必须可以hash 列表不能hash  set的元素要求必须可以hash  目前学过的不可hash的类型有list、set... 元素不可以索引  set可以迭代  set增加  add(elem)  增加一个元素到set中  如果元素存在,什么都不做  update(*others)  合并其他元素到set元素中来  参数others...< set2  判断set1是否是set2的真子集  issuperset(other)、>=  判断当前集合是否是other的超集  set1 > set2  判断set1是否是set的真超集  isdisjoint

1.6K20

训练集(train set) 验证集(validation set) 测试集(test set)

在有监督(supervise)的机器学习中,数据集常被分成2~3个即: training set是用来训练模型或确定模型参数的,如ANN中权值等; validation set是用来做模型选择(model...selection),即做模型的最终优化及确定的,如ANN的结构;而 test set则纯粹是为了测试已经训练好的模型的推广能力。...当然,test set这并不能保证模型的正确性,他只是说相似的数据用此模型会得出相似的结果。样本少的时候,上面的划分就不合适了。常用的是留少部分做测试集。然后对其余N个样本采用K折交叉验证法。...在应用中,一般只将数据集分成两类,即training set 和test set,大多数文章并不涉及validation set。train训练数据。拟合模型,用这部分数据来建立模型。...但是我们只用测试数据集(Test Set) 去评估模型的表现,并不会去调整优化模型。

9K30

④【Set】Redis常用数据类型: Set

操作命令汇总 Redis的Set是String类型的无序不可重复集合,集合对象的编码可以是intset或者hashtable Redis中Set集合是通过哈希表实现的,添加、删除、查找的复杂度都是O(1...sadd set1 m2 m3 # 返回值是操作成功的个数 2. smembers 遍历集合中所有成员 smembers key # 遍历set1中的所有元素 smembers set1 3. sismember...判断集合中是否存在指定的成员 sismember key member # 判断指定成员是否存在于集合set1 # 1:yes # 0:no sismember set1 m1 sismember set1...spop set1 spop set1 2 8. smove 将指定成员从source移动到destination smove source destination member # 将成员888从set1...移动到set2 smove set1 set2 888 9. sdiff 集合成员的差集运算 sdiff key [key ...] # 返回 属于集合s1 但不属于集合s2的成员 sdiff s1

11910
领券