[C++][数据结构]哈希3:unordered_map和unordered_set的模拟实现

前言

今天我们来试着用哈希封装一下unordered_map和unordered_set这两个容器

由于主要的哈希的模拟实现都在之前的文章中,所以本文只是对于几个小问题进行说明

KeyOfT:取出key

因为我们传的第二个模板参数是T,我们不知道他是key还是pair<K, V>。所以,我们要增加一个模板参数取出data中的key

给出两种实现:MapKeyOfT和SetKeyOfT

cpp 复制代码
		struct MapKeyOfT
		{
			const K& operator()(const pair<K, V>& kv)
			{
				return kv.first;
			}
		};
cpp 复制代码
		struct SetKeyOfT
		{
			const K& operator()(const K& key)
			{
				return key;
			}
		};

Insert:插入

直接调用哈希的Insert就好了(

iterator:迭代器

迭代器的需求:

  • 解引用
  • 自增
  • 不等于

我们要把什么封装成迭代器呢?

节点的指针?

那我们需要知道:当a桶遍历完了,怎么找到a+1号桶呢?

给出的解决方案是:迭代器中给两个成员:节点的指针和哈希桶的指针

cpp 复制代码
using iterator = hash_bucket::HashTable<K, const K, SetKeyOfT, Hash>::iterator;
//hash_bucket 就是哈希桶

解决iterator和HashTable的相互引用

因为iterator和Hash Table中都是用到了对方,所以编译的时候编译器在他们的前面找不到(比如,iterator写在前面,但找不到HashTable:因为编译的时候是往iterator的前面找,而不是往后面找)

所以我们要在iterator前面先声明一下:前置声明

注意:前置声明要去掉缺省参数。

解决_tables私有成员无法访问

在operator++()中,我们用到了_tables.size(),但他是私有成员,无法访问,怎么解决呢?

有两种方法:

  1. 写一个GetTables,取出私有成员
  2. 写一个类模板的友元

类模板的友元要加上模板的声明

operator[]

先Insert,插入无论成功还是失败都返回指针

总结

本文到这里就结束了,希望对你有帮助~

相关推荐
violet-lz4 分钟前
数据结构八大排序:归并排序-原理+C语言实现+优化+面试题
c语言·数据结构·排序算法
如竟没有火炬32 分钟前
全排列——交换的思想
开发语言·数据结构·python·算法·leetcode·深度优先
嵌入式小李.man1 小时前
C++第十三篇:继承
开发语言·c++
kyle~2 小时前
C++---嵌套类型(Nested Types)封装与泛型的基石
开发语言·c++·算法
熬了夜的程序员2 小时前
【LeetCode】82. 删除排序链表中的重复元素 II
数据结构·算法·leetcode·链表·职场和发展·矩阵·深度优先
胖咕噜的稞达鸭4 小时前
AVL树手撕,超详细图文详解
c语言·开发语言·数据结构·c++·算法·visual studio
CSCN新手听安4 小时前
【linux】多线程(六)生产者消费者模型,queue模拟阻塞队列的生产消费模型
linux·运维·服务器·c++
-SGlow-4 小时前
Linux相关概念和易错知识点(48)(epoll的底层原理、epoll的工作模式、反应堆模式)
linux·服务器·c语言·网络·c++
csdn_aspnet4 小时前
C++ 圆台体积和表面积计算程序(Program for Volume and Surface area of Frustum of Cone)
c++
阿林学习计算机5 小时前
红黑树的实现
数据结构