题解 | #在二叉树中找到两个节点的最近公共祖先#

在二叉树中找到两个节点的最近公共祖先

http://www.nowcoder.com/practice/e0cc33a83afe4530bcec46eba3325116

package main
import . "nc_tools"

func lowestCommonAncestor( root *TreeNode ,  o1 int ,  o2 int ) int {
    if root == nil {
        return -1
    }

    node := isParent(root,o1,o2)
    if node != nil {
        return node.Val
    }
    return -1
}

func isParent(root *TreeNode, o1, o2 int) *TreeNode {
    if root == nil {
        return root
    }

    if root.Val == o1 || root.Val == o2 {
        return root
    }

    left := isParent(root.Left, o1, o2)
    right := isParent(root.Right, o1, o2)

    if left == nil {
        return right
    }
    if right == nil {
        return left
    }
    return root
}
全部评论

相关推荐

2025-12-27 16:01
重庆大学 Java
蛊界Go学长林剑行:项目部分,不光要展示技术栈的熟练程度,还要有架构意识+产品意识。知道每个业务逻辑落地的成果和技术选型的思考,不然纯炫技是没意义的,毕竟你用的这些技术大概率跟大厂实际项目不垂直,面试官不一定有兴趣
简历中的项目经历要怎么写
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务