【 C++ 】搜索二叉树


今天介绍一种新的树形结构--搜索二叉树,它是这样定义的。任意节点的左子树小于根小于右子树。注意是所有值,也就是左子树的最大值也小于根,同理,右子树的最小值也大于根。

实现起来也很简单,主要有增删查等功能,注意没有改。我们实现两个版本,一种是只存储一个值_key,一种是存储两个值_key_value。这就是以后会学的set和map雏形。

增加值

如果有一模一样的值默认是不加入的,当然你可以自己调整代码逻辑,我这里是默认不加入。代码很简单,写一个父节点用于追踪,写一个子节点。注意当没有根节点时,直接new根节点然后return true即可,其他情况需要分类讨论。

查找

查找逻辑类似,也非常简单,自己实现即可。

删除

删除逻辑略有些麻烦,需要分类讨论,第一种情况是左右节点都没有,直接delete即可,二三情况就是没有左节点或没有右节点,第一种情况可以并入二三情况。第四种情况就是左右节点都有,直接删除肯定是不行的,所以我们采用替代法,找一个不破坏搜索二叉树定义的值和目标值替换。有两种替换方法,一种是找左子树的最大值,一种是找右子树的最小值。也很简单,一个while循环就搞定了。这里简单列一下核心代码。

cpp 复制代码
if (cur->leftNode == nullptr)
{
				if (cur == _root)
				{
					_root = cur->rightNode;
				}
				else
				{
					if (curParent->leftNode == cur)
						curParent->leftNode = cur->rightNode;
					else
						curParent->rightNode = cur->rightNode;
				}

				delete cur;
}

else if (cur->rightNode == nullptr)
{
				if (cur == _root)
				{
					_root = cur->rightNode;
				}
				else
				{
					if (curParent->leftNode == cur)
						curParent->leftNode = cur->leftNode;
					else
						curParent->rightNode = cur->leftNode;
				}

				delete cur;
}

else
{
				Node* replaceParent = cur;
				Node* replace = cur->rightNode;
				while (replace->leftNode)
				{
					replaceParent = cur;
					replace = replace->leftNode;
				}
				cur->_key = replace->_key;

				if (replaceParent->_left == replace)
					replaceParent->_left = replace->_right;
				else
					replaceParent->_right = replace->_right;

				delete replace;
				
}
return true;

整体来说搜索二叉树就是一个过渡的知识点,可以自己实现一下,检验一下自己c++类和对象以及模版的学习成果。

相关推荐
SamDeepThinking6 分钟前
第1篇-开篇词:几亿用户规模下,我们是怎么做C端高并发商品系统的
java·后端·架构
weisian1517 分钟前
Java并发编程--47-分布式ID生成器:雪花算法(Snowflake)与时钟回拨问题
java·算法·时钟回拨·雪花算法id
itzixiao8 分钟前
L1-066 猫是液体(5分)[java][python]
java·开发语言·python·算法
ytttr87310 分钟前
MATLAB SIFT图像配准实现
算法·机器学习·matlab
小饕13 分钟前
从 Word2Vec 到多模态:词嵌入技术的演进全景
人工智能·算法·机器学习
海参崴-14 分钟前
AVL树完整实现与深度解析
算法
Lightning-py15 分钟前
Python 配置日志(Logging)
开发语言·python
冷小鱼15 分钟前
MyBatis 与 MyBatis-Plus:从入门到精通的完整指南
java·tomcat·mybatis
隔窗听雨眠20 分钟前
MySQL主从延迟根因诊断法
开发语言·php
一个爱编程的人22 分钟前
一个数是不是素数
数据结构·算法