题解 | #农场牛群族谱#

农场牛群族谱

https://www.nowcoder.com/practice/7d28855a76784927b956baebeda31dc8?tpId=354&tqId=10591685&ru=/exam/oj&qru=/ta/interview-202-top/question-ranking&sourceUrl=%2Fexam%2Foj

import java.util.*;

/*
 * public class TreeNode {
 *   int val = 0;
 *   TreeNode left = null;
 *   TreeNode right = null;
 *   public TreeNode(int val) {
 *     this.val = val;
 *   }
 * }
 */

public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param root TreeNode类 
     * @param p int整型 
     * @param q int整型 
     * @return int整型
     */
    public int lowestCommonAncestor (TreeNode root, int p, int q) {
        if(root == null){
            return -1;
        }
        if (root.val == p || root.val == q)
            return root.val;
        int left = lowestCommonAncestor(root.left,p,q);
        int right = lowestCommonAncestor(root.right,p,q);

        if(left>=0&&right>=0){
            return root.val;
        }

        return left==-1?right:left;
    }
}

本题知识点分析:

1.二叉树遍历

2.递归

本题解题思路分析:

1.如果节点为Null,返回-1

2.先判断当前节点的值是否为p和q其中之一,如果是,直接返回节点的值,因为用例有{1,2},1,2,返回1的情况

3.如果当前节点不是共同祖先,分别递归左子树和右子树

4.如果左右子树都>=0说明有结果,找到了,因此当前节点就是题目要求返回的节点

5.如果没有找到,要么在左子树,要么在右子树,根据返回-1的情况就可以选择另外一个子树即可。

本题使用编程语言: Java

如果本篇文章对您有帮助的话,可以点个赞支持一下,感谢~

全部评论

相关推荐

King987:待优化的地方还是挺多的,可以参考一下我的作品优化一下,优化不好的话也可以找我
点赞 评论 收藏
分享
02-01 12:05
复旦大学 Java
腾讯的提前批大概率应该是没有笔试的,但是这个时候有相当部分的同学简历估计都没有准备好,没准备好的同学也不用急,大部分都是3月之后开,这个时候开的绝大多数都是神仙打架,问的东西也比较难,打算投递的同学也多看下计算机网络和操作系统,腾讯对这部分的知识问的比较多。另外多刷下牛客的热门题库,刷题注意刷ACM模式,和牛客的周赛题,腾讯有的部门会从这里面出原题。我是@程序员花海关注我,带你了解更多校招资讯!
程序员花海:还没有来得及准备的同学可以看下学习路线:https://www.nowcoder.com/discuss/824693499982315520?sourceSSR=users算法题:https://www.nowcoder.com/feed/main/detail/20e7a999fa04485b88340a274411ca0d?sourceSSR=users八股文:https://www.nowcoder.com/discuss/833102362771251200?sourceSSR=users简历书写方式:https://www.nowcoder.com/discuss/839907820706205696?sourceSSR=users都是以前在牛客发的文章~
软开人,秋招你打算投哪些...
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

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