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;
    }
};
相关推荐
hehelm几秒前
string的模拟实现
数据结构·算法
白羊by2 分钟前
逻辑回归与Softmax的区别
算法·机器学习·逻辑回归
Tisfy5 分钟前
LeetCode 3761.镜像对之间最小绝对距离:哈希表(维护左,枚举右)
算法·leetcode·散列表·题解
小鱼~~5 分钟前
逻辑回归简介
算法·机器学习·逻辑回归
黎阳之光9 分钟前
黎阳之光受邀出席上海口岸联合会2026智慧口岸研讨班 无感通关方案获盛赞
大数据·人工智能·算法·安全·数字孪生
TU^11 分钟前
C++11(二)
c++·算法
阿Y加油吧14 分钟前
两道经典子序列 / 子数组 DP 题:最长递增子序列 & 乘积最大子数组
算法
混凝土拌意大利面14 分钟前
量子退相干提升区块链安全新范式
算法·安全·区块链·共识算法
故事和你9110 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
脱氧核糖核酸__10 小时前
LeetCode热题100——53.最大子数组和(题解+答案+要点)
数据结构·c++·算法·leetcode