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

复制代码
https://leetcode.cn/problems/lowest-common-ancestor-of-a-binary-tree/?envType=study-plan-v2&envId=top-interview-150
复制代码
思路:因为自己可以是自己的祖先,所以这题其实是在问哪棵子树(最小)可以同时将两个节点包含,我们需要返回该子树的根节点;因为没有重复数所以我们可以用cnt来记录以当前节点为根的子树包含这两个节点的数量,我们可以用cnt=当前节点本身是否相等+左右子树包含的数量, 就可以算出当前节点为根的子树包含这两个节点的数量,当第一次等于2的时候就代表我们找到了。
java 复制代码
public class Main {
    int cnt = 0;
    TreeNode goal = null;
    boolean flag = false;
    public class TreeNode {
        int val;
        TreeNode left;
        TreeNode right;

        TreeNode() {
        }

        TreeNode(int val) {
            this.val = val;
        }

        TreeNode(int val, TreeNode left, TreeNode right) {
            this.val = val;
            this.left = left;
            this.right = right;
        }
    }
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        method(root, p, q);
        return goal;
    }

    public int method(TreeNode node, TreeNode p, TreeNode q) {
        if (node == null) {
            return 0;
        }
        //当前节点为根的子树包含这两个节点的数量
        int cnt = ((node.val == p.val || node.val == q.val) ? 1 : 0) + method(node.left, p, q) + method(node.right, p, q);
        // 第一次等于2,我们记录一下根节点,后续不再进入该部分
        if (cnt == 2 && !flag) {
            goal = node;
            flag = true;
        }
        return cnt;
    }
}
相关推荐
折哥的程序人生 · 物流技术专研10 小时前
《Java 100 天进阶之路》第93篇:Redis实战应用:缓存策略与分布式锁(2026版)
java·redis·缓存·面试·架构·求职招聘
瓦特what?10 小时前
位运算核心技巧与应用
java·jvm·算法
人道领域10 小时前
【LeetCode刷题日记】90.子集Ⅱ--- 归纳题解
java·开发语言·leetcode
IT策士10 小时前
Redis 从入门到精通:数据结构Set 与 Sorted
数据结构·数据库·redis
ch.ju10 小时前
Java Programming Chapter 4——Characteristics of inheritance
java·开发语言
就叫_这个吧10 小时前
tomcat在idea控制台乱码问题解决
java·tomcat·intellij-idea
霸道流氓气质10 小时前
Spring AI Alibaba Skills 完整实战:从零构建智能会议助手
java·人工智能·spring
极客先躯10 小时前
高级java每日一道面试题-2026年02月04日-实战篇[Docker]-如何在容器之间共享数据?
java·运维·网络·docker·容器·自动化·高级面试题
真实的菜10 小时前
微服务架构痛点
java·微服务·架构
小楊不秃头10 小时前
Spring:Bean的存储
java·spring·bean