力扣算法 Java 刷题笔记【二叉树篇】hot100(十)GIT原理之最近公共祖先(二叉树的最近公共祖先)中等 1

1. 二叉树的最近公共祖先 (中等)

地址: https://leetcode-cn.com/problems/lowest-common-ancestor-of-a-binary-tree/comments/
2021/12/15
做题反思:

class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if (root == null) {
            return null;
        }
        if (root == p || root == q) {
            return root;
        }
        TreeNode left = lowestCommonAncestor(root.left, p, q);
        TreeNode right = lowestCommonAncestor(root.right, p, q);
        if (left == null && right == null) {
            return null;
        } 
        if (left != null && right != null) {
            return root;
        }
        
        return left == null ? right : left;
    }
}

在这里插入图片描述



我们前文 学习数据结构和算法的框架思维 就说过了,所有二叉树的套路都是一样的:

void traverse(TreeNode root) {
    // 前序遍历
    traverse(root.left)
    // 中序遍历
    traverse(root.right)
    // 后序遍历
}

所以,只要看到二叉树的问题,先把这个框架写出来准没问题:

TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
    TreeNode left = lowestCommonAncestor(root.left, p, q);
    TreeNode right = lowestCommonAncestor(root.right, p, q);
}

现在我们思考如何添加一些细节,把框架改造成解法。

labuladong 告诉你,遇到任何递归型的问题,无非就是灵魂三问:

1、这个函数是干嘛的?

2、这个函数参数中的变量是什么?

3、得到函数的递归结果,你应该干什么?

呵呵,看到这灵魂三问,你有没有感觉到熟悉?本号的动态规划系列文章,篇篇都在说的动态规划套路,首先要明确的是什么?是不是要明确「定义」「状态」「选择」,这仨不就是上面的灵魂三问吗?

posted @ 2022-03-04 23:03  涤心  阅读(40)  评论(0)    收藏  举报