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

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

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

思路

看到各位大佬的思路基本都是找到一个节点后再找父节点再找另外一个节点,思路听起来比较复杂,我在这里分享一个比较简单的思路:
首先对树进行两次遍历(可以优化成一次)找到这两个节点,同时记录根节点到这两个节点的路径, 然后对两个节点的路径进行遍历比较, 从
根节点开始比较, 最后一次两个路径上节点相同就是这两个节点的父节点.

java代码

import java.util.*;

/*
 * public class TreeNode {
 *   int val = 0;
 *   TreeNode left = null;
 *   TreeNode right = null;
 * }
 */

public class Solution {
    /**
     *
     * @param root TreeNode类
     * @param o1 int整型
     * @param o2 int整型
     * @return int整型
     */
    public int lowestCommonAncestor (TreeNode root, int o1, int o2) {
        // write code here
        if(root == null) return 0;
        Deque<Integer> stack1 = new ArrayDeque<>();
        Deque<Integer> stack2 = new ArrayDeque<>();
        findTrace(root, o1, stack1);      //获得根节点到o1的路径
        findTrace(root, o2, stack2);      //获得根节点到o2的路径
        int result = 0;
        int temp = 0;
        while(stack1.size()!=0 && stack2.size()!=0 &&  (temp = stack1.pollFirst()) == stack2.pollFirst()){result = temp;} //比较两个路径, 
                                                                                                          //出现不一致说明不是父节点了
        return result;
    }

    public static boolean findTrace(TreeNode node, int val, Deque<Integer> stack){
        if(node == null) return false;

        if(node.val != val){
            stack.offerLast(node.val);
            if(findTrace(node.left, val, stack)) return true;
            if(findTrace(node.right, val, stack)) return true;
            stack.pollLast();
            return false;
        } else {
            stack.offerLast(node.val);
            return true;
        }

    }
}
全部评论

相关推荐

群星之怒:1.照片可以换更好一点的,可以适量P图,带一些发型,遮住额头,最好穿的正式一点,可以适当P图。2.内容太少。建议添加的:求职意向(随着投递岗位动态更改);项目经历(内容太少了建议添加一些说明,技术栈:用到了什么技术,还有你是怎么实现的,比如如何确保数据传输稳定的,角色注册用到了什么技术等等。)项目经历是大头,没有实习是硬伤,如果项目经理不突出的话基本很难过简历筛。3.有些内容不必要,比如自我评价,校内实践。如果实践和工作无关千万别写,不如多丰富丰富项目。4.排版建议:建议排版是先基础信息,然后教育背景(要突出和工作相关的课程),然后专业技能(一定要简短,不要长篇大论,写你会什么,会的程度就可以),然后是项目经历(一定要详细,占整个简历一定要超过一半,甚至超过百分之70都可以)。最后如果有一部分空白的话可以填补上校内获得的专业相关的奖项,没有就写点校园经历和自我评价。5.技术一定要够硬,禁得住拷打。还有作息尽量保证正常,不要太焦虑。我24双非本科还是非科班,秋招春招各找了一段实习结果都没有转正,当时都想噶了,最后6月份在校的尾巴也找到一份工作干到现在,找工作有时很看运气的不要急着自我否定。 加油
点赞 评论 收藏
分享
03-27 17:33
门头沟学院 Java
代码飞升:同学院本,你要注意hr当天有没有回复过,早上投,还要打招呼要推销自己,不要一个劲投
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务