Day119 | 灵神 | 二叉树 | 二叉树的最近共公共祖先

Day119 | 灵神 | 二叉树 | 二叉树的最近共公共祖先

236.二叉树的最近共公共祖先

236. 二叉树的最近公共祖先 - 力扣(LeetCode)

思路:

二叉树的最近公共祖先【基础算法精讲 12】_哔哩哔哩_bilibili

首先我们采用后序遍历

递归函数返回值是问是「最近公共祖先的候选项」。对于最外层的递归调用者来说,返回值是最近公共祖先的意思。但是,在递归过程中,返回值可能是最近公共祖先,也可能是空节点(表示子树内没找到任何有用信息)、节点 p 或者节点 q(可能成为最近公共祖先,或者用来辅助判断上面的某个节点是否为最近公共祖先)。

1.当前节点的是空节点

那就返回空

2.当前结点是p或者q,直接返回当前结点就行

比如5是p,4是q,那么我们遍历到5就直接返回5就行,因为5是5和4的最近公共祖先

3.如果左右子树都有的话,也就是pq分别在这当前结点的左右子树,那么最近公共祖先就是当前结点

4.如果只在左子树中找到了q或者p,那说明最近公共祖先肯定在左子树,返回遍历左子树的结果就行

右子树是同理的

5.当前结点的左右子树都没找到p或者q,那说明在其他的子树

返回nullptr

完整代码:

cpp 复制代码
class Solution {
public:
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        //1.当前结点为空或者q或者p,返回当前结点
        if(root==nullptr || root==p || root==q)
            return root;
        TreeNode *l=lowestCommonAncestor(root->left,p,q);
        TreeNode *r=lowestCommonAncestor(root->right,p,q);
        //2.左右子树中分别找到了p或者q
        if(l!=nullptr&&r!=nullptr)
            return root;
        //3.p和q全在右子树中
        else if(l==nullptr&&r!=nullptr)
            return r;
        //4.p和q全在左子树中
        else if(l!=nullptr&&r==nullptr)
            return l;
        //5.q和p不在当前子树
        else
            return nullptr;
    }
};
相关推荐
楼田莉子几秒前
C++20新特性:Range库
开发语言·c++·后端·学习·c++20
字节高级特工1 分钟前
【Linux】深入理解C语言命令行参数与环境变量
linux·c++·人工智能·后端
linux开发之路6 分钟前
C++项目推荐:eBPF+调度器性能分析框架
linux·c++·ebpf·火焰图·调度器
愿天垂怜12 分钟前
【C++脚手架】ffmpeg 库的介绍与使用
linux·服务器·开发语言·c++·ide·git·ffmpeg
Eric 辰东13 分钟前
【C 语言程序的编译和链接】详解编译链接过程
c语言·笔记·算法·学习方法
并不喜欢吃鱼13 分钟前
从零开始 C++-----十一【C++ 数据结构】红黑树全解析:从定义到工程实现(一文搞定,十分详细)
开发语言·数据结构·c++
星恒随风13 分钟前
C语言数据结构排序算法详解(上):从插入排序、希尔排序到选择排序、堆排序
c语言·数据结构·笔记·学习·排序算法
不会C语言的男孩14 分钟前
C++ Primer Plus 第7章:函数——C++的编程模块
开发语言·c++
迈巴赫车主16 分钟前
蓝桥杯21247弹跳鞋java
java·开发语言·数据结构·算法·职场和发展·蓝桥杯
kebeiovo19 分钟前
C++与 Lua的交互
c++·lua