小学生都懂题解 | #在二叉树中找到两个节点的最近公共祖先#

在二叉树中找到两个节点的最近公共祖先

https://www.nowcoder.com/practice/e0cc33a83afe4530bcec46eba3325116

问题描述

我们需要在一个非空的二叉树中找到两个节点 o1o2 的最近公共祖先节点。这里的“最近公共祖先”指的是离这两个节点最近的共同的祖先节点。

解决方案

我们可以用一种简单的方法来解决这个问题,通过递归地查找树中的节点。下面是详细的步骤:

  1. 定义方法:
  2. 我们定义一个方法 lowestCommonAncestor,它接收三个参数:二叉树的根节点 root,以及两个节点的值 o1 和 o2。
  3. 基本情况:
  4. 如果当前节点(也就是根节点)是 null(即不存在),那么返回 -1(表示没有找到公共祖先)。
  5. 如果当前节点的值正好是 o1 或 o2 中的一个,那么当前节点可能是其中一个节点的公共祖先。
  6. 递归查找:
  7. 我们从当前节点出发,分别递归地查找左子树和右子树。
  8. 如果在左子树中找到了一个公共祖先,返回这个公共祖先的值。
  9. 如果在右子树中找到了一个公共祖先,返回这个公共祖先的值。
  10. 组合结果:
  11. 如果在左子树和右子树中都找到了节点(即两个递归结果都不为空),那么当前节点就是 o1 和 o2 的最近公共祖先。
  12. 如果只在左子树中找到了一个节点,那么返回左子树的结果。
  13. 如果只在右子树中找到了一个节点,那么返回右子树的结果。
  14. 如果左右子树都没有找到节点,那么返回 -1。

示例代码解释

class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;
    TreeNode(int x) { val = x; }
}

public class Solution {
    // 主方法用来查找最近公共祖先
    public int lowestCommonAncestor(TreeNode root, int o1, int o2) {
        if (root == null) {
            return -1; // 基本情况:如果根节点为空,返回-1
        }

        // 如果当前节点的值等于 o1 或 o2,返回当前节点的值
        if (root.val == o1 || root.val == o2) {
            return root.val;
        }

        // 递归地在左子树中查找
        int left = lowestCommonAncestor(root.left, o1, o2);
        // 递归地在右子树中查找
        int right = lowestCommonAncestor(root.right, o1, o2);

        // 如果左右子树的递归结果都不为空,那么当前节点就是最近公共祖先
        if (left != -1 && right != -1) {
            return root.val;
        }

        // 如果只有左子树的递归结果不为空,那么左子树的递归结果就是最近公共祖先
        if (left != -1) {
            return left;
        }

        // 如果只有右子树的递归结果不为空,那么右子树的递归结果就是最近公共祖先
        if (right != -1) {
            return right;
        }

        // 如果左右子树的递归结果都为空,说明没有找到节点 o1 或 o2
        return -1;
    }
}

如果这篇文章对你有帮助,请点个免费的赞👍,让它帮助更多的人。

#牛客创作赏金赛#
小学生都能看懂的算法 文章被收录于专栏

主要面向小白的算法文章。以小学生都能看懂为目标而编写,顺便巩固下自己。

全部评论

相关推荐

10-18 13:01
已编辑
西安理工大学 C++
小米内推大使:建议技能还是放上面吧,hr和技术面试官第一眼想看的应该是技能点和他们岗位是否匹配
点赞 评论 收藏
分享
威猛的小饼干正在背八股:挂到根本不想整理
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务