首页 > 后端开发 > C++ > 正文

c++中如何在二叉搜索树删除节点_c++二叉搜索树删除节点方法

尼克
发布: 2025-10-28 15:45:01
原创
972人浏览过
删除二叉搜索树节点需分三种情况处理:1. 无子节点则直接删除;2. 仅一个子节点时用其替代;3. 有两个子节点则用右子树最小值(中序后继)替换并递归删除该值,确保BST性质不变。

c++中如何在二叉搜索树删除节点_c++二叉搜索树删除节点方法

在C++中删除二叉搜索树(BST)中的节点是一个经典问题,需要根据节点的子节点情况分类处理。核心原则是保持BST的性质:左子树所有值小于根,右子树所有值大于根。

删除节点的三种情况

假设要删除的节点为 target,处理方式如下:

  • 无子节点(叶子节点):直接删除,父节点对应指针置空。
  • 只有一个子节点:用子节点替代当前节点。
  • 有两个子节点:找到右子树中的最小值(中序后继),用其值替换当前节点值,然后删除那个最小节点。

节点结构定义

struct TreeNode {
    int val;
    TreeNode* left;
    TreeNode* right;
    TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};
登录后复制

删除操作实现

使用递归方式实现删除函数:

TreeNode* deleteNode(TreeNode* root, int key) {
    if (!root) return nullptr;
<pre class='brush:php;toolbar:false;'>if (key < root->val) {
    root->left = deleteNode(root->left, key);
} else if (key > root->val) {
    root->right = deleteNode(root->right, key);
} else {
    // 找到目标节点,开始删除
    if (!root->left) {
        TreeNode* temp = root->right;
        delete root;
        return temp;
    } else if (!root->right) {
        TreeNode* temp = root->left;
        delete root;
        return temp;
    }

    // 有两个子节点:找右子树的最小节点(中序后继)
    TreeNode* minNode = root->right;
    while (minNode->left) {
        minNode = minNode->left;
    }
    root->val = minNode->val; // 替换值
    root->right = deleteNode(root->right, minNode->val); // 删除后继
}
return root;
登录后复制

}

立即学习C++免费学习笔记(深入)”;

纳米搜索
纳米搜索

纳米搜索:360推出的新一代AI搜索引擎

纳米搜索30
查看详情 纳米搜索

关键点说明

为什么选择中序后继?因为它的值是右子树中最小的,刚好大于当前节点的左子树所有值,替换后仍满足BST性质。也可以选择左子树的最大值(中序前驱),逻辑对称。

递归返回 root 很重要,确保父节点能正确连接调整后的子树。

基本上就这些,理解三种情况和递归结构就能正确实现删除操作。

以上就是c++++中如何在二叉搜索树删除节点_c++二叉搜索树删除节点方法的详细内容,更多请关注php中文网其它相关文章!

相关标签:
c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号