代码随想录算法训练营第22天 235. 二叉搜索树的最近公共祖先 701.二叉搜索树中的插入操作 450.删除二叉搜索树中的节点

235. 二叉搜索树的最近公共祖先

给定一个二叉搜索树,可以利用它的性质(左子树上所有节点的值都小于根节点的值,右子树上所有节点的值都大于根节点的值)找到两个节点的最近公共祖先。因此,可以进行如下操作:

  • 如果节点p和节点q都在root的右边,则公共祖先必然在root的右子树中,所以我们将搜索范围缩小为root的右子树。

  • 如果节点p和节点q都在root的左边,同理,我们将搜索范围缩小为root的左子树。

  • 如果条件1和条件2都不满足,说明节点p和节点q分别在root的两侧,所以,root就是我们要找的最近公共祖先。

    /**

    • Definition for a binary tree node.
    • public class TreeNode {
    • 复制代码
      int val;
    • 复制代码
      TreeNode left;
    • 复制代码
      TreeNode right;
    • 复制代码
      TreeNode(int x) { val = x; }
    • }
      */

    class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {

    复制代码
          while(true){
              if(root.val < p.val && root.val < q.val){
                  // p, q 都在root的右子树中
                  root = root.right;
              } else if(root.val > p.val && root.val > q.val){
                  // p, q 都在root的左子树中
                  root = root.left;
              } else {
                  break;
              }
          }
    
          return root;
      }

    }

701. 二叉搜索树中的插入操作

左子树上所有节点的值都小于根节点的值,右子树上所有节点的值都大于根节点的值。我们将新的值与根节点的值进行比较,如果新值小于当前节点的值,我们就在左子树上进行这个操作;如果新值大于当前节点的值,我们就在右子树上进行这个操作。如果遇到当前节点为空,就在这个位置插入新的值。

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public TreeNode insertIntoBST(TreeNode root, int val) {
        // 如果根节点为空 那么新值就会被插入到这个位置
        if(root == null){
            return new TreeNode(val);
        }

        // 如果新值大于当前节点的值 那么就在右子树上插入新值
        if(val > root.val){
            root.right = insertIntoBST(root.right,val);
        }
        // 如果新值小于当前节点的值 那么就在左子树插入新值
        else if(val < root.val){
            root.left = insertIntoBST(root.left,val);
        }

        return root;
    }
}

450. 删除二叉搜索树中的节点

删除二叉搜索树中的一个节点有以下几个步骤:

  1. 如果节点为空(即,树为空),我们直接返回 null。
  2. 如果 key 大于当前节点的值,我们需要在右子树中删除;
  3. 如果 key 小于当前节点的值,我们需要在左子树中删除;
  4. 如果 key 等于当前节点的值,那么我们需要删除这个节点,有以下几种情况:
    • 节点是叶子节点(即没有子节点),我们可以直接删除节点,返回 null;
    • 节点只有一个非空子节点,我们可以直接让它的子节点替代自己;
    • 节点有两个子节点,那么我们需要找到左子树中的最大节点(或右子树中的最小节点)来替代自己,然后删除那个节点。
java 复制代码
class Solution {
    public TreeNode deleteNode(TreeNode root, int key) {
        if (root == null) {
            return null;
        }
        if (key > root.val) { 
            // 在右子树中删除
            root.right = deleteNode(root.right, key);
        } else if (key < root.val) {
            // 在左子树中删除
            root.left = deleteNode(root.left, key);
        } else {
            // 当前节点就是需要删除的节点
            if (root.left == null) {
                // 如果没有左子节点,让右子节点替代自己
                return root.right;
            } else if (root.right == null) {
                // 如果没有右子节点,让左子节点替代自己
                return root.left;
            } else {
                // 如果有两个子节点,找到左子树中的最大节点来替代自己
                TreeNode maxNode = findMax(root.left);
                root.val = maxNode.val;
                // 删除左子树中的最大节点
                root.left = deleteNode(root.left, maxNode.val);
            }
        }
        return root;
    }

    private TreeNode findMax(TreeNode node) {
        while (node.right != null) {
            node = node.right;
        }
        return node;
    }
}
相关推荐
yuuki2332333 小时前
【C++】类和对象(上)
c++·后端·算法
dangdang___go3 小时前
动态内存管理||malloc和free.realloc和calloc
c语言·开发语言·算法·动态内存管理
数字化脑洞实验室3 小时前
智能决策与决策优化:从算法到产业的演进逻辑
算法
cpp_25013 小时前
P5412 [YNOI2019] 排队
数据结构·c++·算法·题解·洛谷
kingmax542120083 小时前
图论核心算法(C++):包括存储结构、核心思路、速记口诀以及学习方法, 一站式上机考试学习【附PKU百练,相关练习题单】
c++·算法·图论·信奥赛·上机考试·百练·pku
罗湖老棍子3 小时前
【例9.15】潜水员(信息学奥赛一本通- P1271)
c++·算法·动态规划·二维费用背包
_OP_CHEN3 小时前
算法基础篇:(二十一)数据结构之单调栈:从原理到实战,玩转高效解题
数据结构·算法·蓝桥杯·单调栈·算法竞赛·acm/icpc
q***51895 小时前
【语义分割】12个主流算法架构介绍、数据集推荐、总结、挑战和未来发展
算法·架构
Ghost-Silver5 小时前
《星火》——关于Deepseek的进化速度
笔记·算法
代码游侠8 小时前
日历的各种C语言实现方法
c语言·开发语言·学习·算法