RBTree改造,并模拟实现setmap

news2024/12/25 22:33:46

目录

RBTree改造

给红黑树增加迭代器

前置++

前置--

RBT细节改造

模拟set

模拟map


RBTree改造

给红黑树增加迭代器

前置++

前置++的作用是找下一个较大的节点。

假如我们it指向的是5,++it则是将it指向6。加入it指向的是7,则++it则是将it指向8。

也就是说如果右子树不为空,++it是指向的是右子树的最左节点(较大的)。

如果右子树为空(说明该子树已被访问完),++it应该沿着根路径指向孩子是父亲左孩子的那个祖先

//前置++
	self& operator++() {
		if (_node->_right) {
			Node* min = _node->_right;
			while (min->_left) {
				min = min->_left;
			}
			_node = min;
		}
		else {
			Node* cur = _node;
			Node* parent = cur->_parent;
			while (parent && cur == parent->_right) {//这个循环作用是找父亲的左孩子
				cur = cur->_parent;
				parent = parent->_parent;
			}
			_node = parent;
		}
		return *this;
	}

前置--

前置--的作用是找下一个较小的节点。

 假如it指向的是8,--it则是将it指向7。假如it指向的是12,--it则就将it指向了11。

也就是说如果左子树不为空,--it是指向的是左子树的最右节点(较小的)。

如果左子树为空(说明该子树已被访问完),--it应该沿着根路径指向孩子是父亲右孩子的那个祖先。++it的顺序是左根右,--it的顺序是右根左。

//前置--
	self& operator--() {
		if (_node->_left) {
			Node* max = _node->_left;
			while (max->_right) {
				max = max->_right;
			}
			_node = max;
		}
		else {
			Node* cur = _node;
			Node* parent = cur->_parent;
			while (parent && cur == parent->_left) {
				cur = parent;
				parent = parent->_parent;
			}
			_node = parent;
		}
		return *this;
	}

RBT细节改造

1、将节点存放数据的位置改为_data,也就是说无论是set还是map存放的数据都在这个_data里面。

template<class T>
struct rbtreeNode{
	rbtreeNode<T>* _left;
	rbtreeNode<T>* _right;
	rbtreeNode<T>* _parent;
	T _data;
	Color _col;
	rbtreeNode(const T& data)
		:_left(nullptr)
		,_right(nullptr)
		,_parent(nullptr)
		,_col(RED)
		,_data(data)
	{}
};

2、采用上边的方式的话,需要在RBTree中的函数模板中增加一个KeyOfT的仿函数,用于取set中的值,和map中的key进行比较。

3、迭代器的begin的位置应该找到最左节点(最小)

iterator begin() {
		Node* min = _pHead;
		while (min && min->_left) {
			min = min->_left;
		}
		return iterator(min);
	}

4、插入的返回值修改为pair<iterator,bool>类型,方便后边map的operator[]的实现

5、查找的返回值原本是Node*,而迭代器也相当于指针,所以也将放回置修改为迭代器

模拟set

set的底层就是红黑树,因此set的私有成员的类型就是红黑树。

RBTree<K, K, SetKeyOfT> _rt;

set里边需要写一个仿函数,让红黑树能拿到存储的数据。并将这个仿函数类型传给红黑树

struct SetKeyOfT {
		const K& operator()(const K& k) {
			return k;
		}
	};

其他的接口复用红黑树的就行了。完整的代码如下:

#pragma once
#include "RBTree1.h"
template<class K>
class mySet {
public:
	struct SetKeyOfT {
		const K& operator()(const K& k) {
			return k;
		}
	};
	typedef typename RBTree<K, K, SetKeyOfT>::iterator iterator;
	iterator begin() {
		return _rt.begin();
	}
	iterator end() {
		return _rt.end();
	}
	pair<iterator,bool> insert(const K& key) {
		return _rt.Insert(key);
	}
	iterator find(const K& key) {
		return _rt.Find();
	}
	size_t size() {
		return _rt.Size();
	}
private:
	RBTree<K, K, SetKeyOfT> _rt;
};
void test_MySet() {
	mySet<int> ms;
	int a[] = { 7,4,1,8,5,2,9,6,3 };
	for (auto e : a) {
		ms.insert(e);
	}
	mySet<int>::iterator it = ms.begin();
	while (it != ms.end()) {
		cout << *it << " ";
		++it;
	}
	cout << endl;
	cout << "size:" << ms.size() << endl;
}

模拟map

map的模拟和set类似,底层也是红黑树。我们这里说说map的operator[]的逻辑。insert的返回值是pair<iterator, bool>类型,insert插入原来没有的数据时,返回的是新插入节点的迭代器,并返回true。如果插入原本有的数据的时候,返回的是这个存在的key的迭代器,bool值为false而operator[]就是依赖这个insert来实现的。operator[]的返回值是value的引用,也就是说我们可以通过operator[]对value进行查找、修改和插入等操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/542505.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

三十八、流控效果、

1、流控效果 流控效果是指请求达到流控阈值时应该采取的措施&#xff0c;包括三种&#xff1a; 快速失败&#xff1a;达到阈值后&#xff0c;新的请求会被立即拒绝并抛出FlowException异常。是默认的处理方式。 warm up&#xff1a;预热模式&#xff0c;对超出阈值的请求同样是…

chatgpt赋能Python-python3m

Python 3: 一个新时代的编程语言 在编程的世界里&#xff0c;Python 3可能是当前最为热门的编程语言。Python 3是Python语言的最新版本&#xff0c;代码更加现代化&#xff0c;更加简洁易懂&#xff0c;比Python 2更加易于使用。这篇文章将介绍Python 3的各种特性&#xff0c;…

Git回滚详解

文章目录 git restore撤销工作区文件更改撤销暂存区文件更改 git checkoutgit revert冲突解决具体操作 git resetreset 的作用第 1 步&#xff1a;移动 HEAD&#xff08;--soft&#xff09;第 2 步&#xff1a;更新暂存区&#xff08;--mixed&#xff09;第 3 步&#xff1a;更…

如何写好英文论文中的句子?(下)

1 前情提要 大家先看完上一篇文章如何写好英文论文中的句子&#xff1f;&#xff08;上&#xff09;&#xff0c;再接着往下翻。 10 先说名词&#xff0c;再用代词&#xff08;it、they&#xff09;指代该名词 11 否定词放在句子开头附近 12 否定词的正确位置&#xff1a;助动…

消息通知之系统层事件发布相关流程

前言 Openharmony 3.1Release中存在消息通知的处理&#xff0c;消息通知包括系统层事件发布、消息订阅、消息投递与处理&#xff0c;为了开发者能够熟悉消息的处理流程&#xff0c;本篇文章主要介绍系统层事件发布的相关流程。 整体流程 代码流程 发布消息 { eventAction)w…

自定义颜色编辑选取对话框

一、简介 Qt中已经有一些封装好的对话框&#xff0c;比如QMessageBox、QColorDialog等&#xff0c;使用起来快捷方便&#xff0c;但缺点是我们无法为它们自定义样式&#xff0c;所以可能难以“融入”我们的项目。既然如此&#xff0c;那就自己做一个把。抱着这样的想法&#x…

Android SELinux安全机制与权限管理那些事

文章目录 前言权限管理系统应用特权应用历史漏洞广播的保护机制CVE-2020-0391 SELinux 前言 在 Android 漏洞挖掘和安全研究过程中&#xff0c;不可避免地会涉及到跟 Android SELinux 安全机制打交道&#xff0c;比如当你手握一个 System 应用的路径穿越的漏洞的时候想去覆写其…

DS:基于鸢尾花数据集利用多种数据降维技术(PCA、SVD、MDS、LDA、T-SNE)实现三维可视化

DS&#xff1a;基于鸢尾花数据集利用多种数据降维技术(PCA、SVD、MDS、LDA、T-SNE)实现三维可视化 目录 基于鸢尾花数据集利用多种数据降维技术(PCA、SVD、MDS、LDA、T-SNE)实现三维可视化 # 1、加载示例数据集&#xff08;鸢尾花数据集&#xff09; # 2、数据预处理 # T1、…

媒体专访是品牌初创阶段宣传的重要手段

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 很早以前&#xff0c;有位前辈跟我讲&#xff0c;人的成功分两种&#xff0c;一种是借助平台成功&#xff0c;一种是自己创业成功&#xff0c; 前者成功的概率很大&#xff0c;只需要选好…

【5.18】二、黑盒测试方法—因果图与决策表法

目录 2.3 因果图与决策表法 2.3.1 因果图设计法 2.3.2 决策表 2.3.3 实例&#xff1a;三角形决策表 2.3.4 实例&#xff1a;工资发放决策表 2.3 因果图与决策表法 等价类划分法与边界值分析法主要侧重于输入条件&#xff0c;却没有考虑这些输入之间的关系&#xff0c;如…

单链表和双向链表如何执行删除操作

在实际的软件开发中&#xff0c;从链表中删除一个数据无外乎这两种情况&#xff1a; 删除结点中“值等于某个给定值”的结点&#xff1b;删除给定指针指向的结点。 1.从头结点开始一个一个依次遍历对比&#xff0c;直到找到值等于给定值的结点&#xff0c;然后再通过我前面讲…

LeetCode高频算法刷题记录4

文章目录 1. 二叉树的最近公共祖先【中等】1.1 题目描述1.2 解题思路1.3 代码实现 2. 全排列【中等】2.1 题目描述2.2 解题思路2.3 代码实现 3. 相交链表【简单】3.1 题目描述3.2 解题思路3.3 代码实现 4. 合并 K 个升序链表【困难】4.1 题目描述4.2 解题思路4.3 代码实现 5. 环…

chatgpt赋能Python-python3_4怎么下载

Python3.4的下载和安装 Python是一种流行的编程语言&#xff0c;它被广泛用于算法学习、数据分析和网站开发等领域。Python3.4是Python编程语言的一个版本&#xff0c;它在性能和功能方面都得到了改进。如果你希望学习Python3.4或者使用它开发项目&#xff0c;那么你需要下载并…

Jetpack Compose中的附带效应简介及使用

前言 附带效应是指LaunchedEffect、DisposableEffect、rememberCoroutineScope、rememberUpdatedState、produceState 、derivedStateOf的使用。附带效应这4个字在google官方文档上的表达与解释挺让人难以理解的。其实个人认为准确的描述应该是外部产生的数据向Compose状态作用…

chatgpt赋能Python-python3_8_1怎么用

Python3.8.1使用指南&#xff1a;让您的编程更加高效 Python是一种流行的高级编程语言&#xff0c;它以简洁明了的语法和丰富的库而著称。如果您是一名新手或有经验的程序员&#xff0c;Python都是一个很好的选择。在Python3.8.1中&#xff0c;新的功能和改进将进一步提高Pyth…

chatgpt赋能Python-python2的n次方程序

Python2的N次方程序&#xff1a;一个实用的编程工具 Python2是广泛使用的编程语言之一&#xff0c;它是一种强大且灵活的开源语言&#xff0c;被广泛应用于科学计算、数据分析、Web开发等领域。在Python2中&#xff0c;N次方程序是一种非常基础的程序&#xff0c;但是它在实际…

二叉树的基本认识(一)

要了解二叉树&#xff0c;就必然要知道什么是树&#xff0c;树是一种非线性的数据结构&#xff0c;它是由n&#xff08;n>0&#xff09;个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树&#xff0c;也就是说它是根朝上&#xff0c;而叶朝下的…

C++类模板的具体化

目录 分类 代码 分析 一、类模板 一&#xff09;代码 二&#xff09;注意事项 三&#xff09;运行结果 二、完全具体化的模板类 一&#xff09;代码 二&#xff09;注意事项 三&#xff09;执行结果 三、部分具体化的模板类 一&#xff09;代码 二&#xff09;注…

【研发工具】Yapi接口管理平台内网Centos8下搭建

1 环境依赖安装 环境要求 nodejs&#xff08;7.6) &#xff08;本文安装12.18.3&#xff09; mongodb&#xff08;2.6&#xff09;&#xff08;本文安装5.0.17&#xff09; 1.1 安装Nodejs 1.1.1 下载安装包 下载地址&#xff1a;https://nodejs.org/zh-cn/download/这里下载…

代码随想录训练营Day42|背包问题

目录 学习目标 学习内容 416. 分割等和子集 学习目标 01背包问题&#xff0c;你该了解这些&#xff01; 01背包问题&#xff0c;你该了解这些&#xff01; 滚动数组 416. 分割等和子集 学习内容 problems/背包理论基础01背包-1.md programmercarl/leetcode-master&#…