leetcode236—二叉树的最近公共祖先(递归/深搜/理解)

简介: leetcode236—二叉树的最近公共祖先(递归/深搜/理解)

给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。

百度百科中:

最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。”


深搜,找到就返回,判断此时是否左右子树分别含p,q(或者root本身是p或者q)。因为如果pq存在一个子树时(例如都在左子树中),可能左子树结点才是最近公共祖先。

画图,理解返回值的过程。


引用 k神 的递归解析,(主要还是自己画)

递归解析:

终止条件:

当越过叶节点,则直接返回 null ;

当 root 等于 p,q ,则直接返回 root ;

递推工作:

开启递归左子节点,返回值记为 left ;

开启递归右子节点,返回值记为 right ;

返回值: 根据 left 和 right ,可展开为四种情况;

当 left 和 right 同时为空 :说明 root 的左 / 右子树中都不包含 p,q ,返回 null ;

当left 和 right 同时不为空 :说明 p,q 分列在 root 的 异侧 (分别在 左 / 右子树),因此 root 为最近公共祖先,返回 root ;

当 left 为空 ,right 不为空 :p,q 都不在 root 的左子树中,直接返回 right 。具体可分为两种情况:p,q 其中一个在 root 的 右子树 中,此时 right 指向 p(假设为p );

p,q 两节点都在 root 的 右子树 中,此时的 right 指向 最近公共祖先节点 ;

当 left 不为空 , right 为空 :与情况 3. 同理;

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */
struct TreeNode* dfs(struct TreeNode* root,struct TreeNode* p,struct TreeNode* q)
{
    struct TreeNode* l,* r;
    if(root == NULL)
        return NULL;
    if(root == p || root == q)
        return root;
    l = dfs(root->left,p,q);
    r = dfs(root->right,p,q);
    if(l != NULL && r != NULL)
        return root;
    else if(l == NULL && r!= NULL)
        return r;
    else
        return l;
}
struct TreeNode* lowestCommonAncestor(struct TreeNode* root, struct TreeNode* p, struct TreeNode* q) {
    //已知层序遍历的数组 真笨蛋 看错题了 想了半个点
    return dfs(root,p,q);
}
相关文章
|
5天前
leetcode代码记录(二叉树的所有路径
leetcode代码记录(二叉树的所有路径
9 0
|
6天前
|
算法
【刷题】 leetcode 面试题 08.05.递归乘法
递归算法是一种在计算机科学和数学中广泛应用的解决问题的方法,其基本思想是利用问题的自我相似性,即将一个大问题分解为一个或多个相同或相似的小问题来解决。递归算法的核心在于函数(或过程)能够直接或间接地调用自身来求解问题的不同部分,直到达到基本情况(也称为基础案例或终止条件),这时可以直接得出答案而不必再进行递归调用。
23 4
【刷题】 leetcode 面试题 08.05.递归乘法
|
6天前
leetcode代码记录(对称二叉树 中序遍历+回文串 为什么不行
leetcode代码记录(对称二叉树 中序遍历+回文串 为什么不行
7 0
|
6天前
leetcode代码记录(二叉树的最小深度
leetcode代码记录(二叉树的最小深度
9 0
|
6天前
leetcode代码记录(二叉树的最大深度
leetcode代码记录(二叉树的最大深度
8 0
|
5天前
|
算法 C++
【刷题】Leetcode 1609.奇偶树
这道题是我目前做过最难的题,虽然没有一遍做出来,但是参考大佬的代码,慢慢啃的感觉的真的很好。刷题继续!!!!!!
8 0
|
5天前
|
算法 索引
【刷题】滑动窗口精通 — Leetcode 30. 串联所有单词的子串 | Leetcode 76. 最小覆盖子串
经过这两道题目的书写,相信大家一定深刻认识到了滑动窗口的使用方法!!! 下面请大家继续刷题吧!!!
10 0
|
6天前
|
存储 算法 安全
【刷题】 leetcode 面试题 01.06 字符串压缩
来看效果: 非常好!!!过啦!!!
25 5
【刷题】 leetcode 面试题 01.06 字符串压缩
|
6天前
|
存储 算法 测试技术