【 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++类和对象以及模版的学习成果。

相关推荐
颜酱21 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
架构师沉默1 天前
别又牛逼了!AI 写 Java 代码真的行吗?
java·后端·架构
saltymilk1 天前
使用 C++ 模拟 ShaderLanguage 的 swizzle
c++·模板元编程
zone77391 天前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub1 天前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙1 天前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
后端AI实验室1 天前
我把一个生产Bug的排查过程,交给AI处理——20分钟后我关掉了它
java·ai
凉年技术1 天前
Java 实现企业微信扫码登录
java·企业微信