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

题目描述:

主要思路:

利用dfs遍历树,依次判断节点是否为公共祖先节点。

cpp 复制代码
class Solution {
public:
    TreeNode* ans;
    bool dfs(TreeNode* root, TreeNode* p, TreeNode* q)
    {
        if(!root)
            return false;
        bool l=dfs(root->left,p,q);
        bool r=dfs(root->right,p,q);
        if(l&&r||((l||r)&&(root->val==p->val||root->val==q->val)))
            ans=root;
        if(l|r|root->val==p->val|root->val==q->val)
            return true;
        else
            return false;
    }
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        dfs(root,p,q);
        return ans;
    }
};
相关推荐
.格子衫.16 小时前
018数据结构之队列——算法备赛
数据结构·算法
怎么没有名字注册了啊18 小时前
求一个矩阵中的鞍点
数据结构·算法
Greedy Alg18 小时前
LeetCode 74. 搜索二维矩阵
算法
小猪咪piggy18 小时前
【算法】day7 滑动窗口+二分查找
算法
仟千意18 小时前
数据结构:二叉树
数据结构·算法
一水鉴天19 小时前
整体设计 逻辑系统程序 之34七层网络的中台架构设计及链路对应讨论(含 CFR 规则与理 / 事代理界定)
人工智能·算法·公共逻辑
DuHz19 小时前
C程序中的数组与指针共生关系
linux·c语言·开发语言·嵌入式硬件·算法
而后笑面对19 小时前
力扣2025.10.19每日一题
算法·leetcode·职场和发展
·白小白19 小时前
力扣(LeetCode) ——11.盛水最多的容器(C++)
c++·算法·leetcode
沐浴露z20 小时前
【JVM】详解 垃圾回收
java·jvm·算法