zoukankan      html  css  js  c++  java
  • FB面经 Prepare: LCA of Deepest Nodes in Binary Tree

    给一个 二叉树 , 求最深节点的最小公共父节点
         1
      2   3
         5  6    return 3.
    
           1  
        2   3
    4      5 6   retrun 1. 
    先用 recursive  , 很快写出来了, 要求用 iterative 。 时间不够了。。。

    Recursion: 返回的时候返回lca和depth每个node如果有大于一个子节点的depth相同就返回这个node,如果有一个子节点depth更深就返回个子节点lca,这个o(n)就可以了

    Iteration: tree的recursion换成iteration处理,一般用stack都能解决吧(相当于手动用stack模拟recursion)。感觉这题可以是一个样的做法,换成post order访问,这样处理每个node的时候,左右孩子的信息都有了,而且最后一个处理的node一定是tree root

    我的想法是要用hashMap<TreeNode, Info>

    class Info{

      int height;

      TreeNode LCA;

    }

     1 package fbOnsite;
     2 
     3 
     4 public class LCA2 {
     5     private class ReturnVal {
     6         public int depth;   //The depth of the deepest leaves on the current subtree
     7         public TreeNode lca;//The lca of the deepest leaves on the current subtree
     8 
     9         public ReturnVal(int d, TreeNode n) {
    10             depth = d;
    11             lca = n;
    12         }
    13     }
    14 
    15     public TreeNode LowestCommonAncestorOfDeepestLeaves(TreeNode root) {
    16         ReturnVal res = find(root);
    17         return res.lca;
    18     }
    19 
    20     private ReturnVal find(TreeNode root) {
    21         if(root == null) {
    22             return new ReturnVal(0, null);
    23         } else {
    24             ReturnVal lRes = find(root.left);
    25             ReturnVal rRes = find(root.right);
    26 
    27             if(lRes.depth == rRes.depth) {
    28                 return new ReturnVal(lRes.depth+1, root);
    29             } else {
    30                 return new ReturnVal(Math.max(rRes.depth, lRes.depth)+1, rRes.depth>lRes.depth?rRes.lca:lRes.lca);
    31             }
    32         }
    33     }
    34 
    35 
    36 
    37 
    38 /**
    39  * @param args
    40  */
    41     public static void main(String[] args) {
    42         // TODO Auto-generated method stub
    43         TreeNode t1 = new TreeNode(1);
    44         TreeNode t2 = new TreeNode(2);
    45         TreeNode t3 = new TreeNode(3);
    46         TreeNode t4 = new TreeNode(4);
    47         TreeNode t5 = new TreeNode(5);
    48         TreeNode t6 = new TreeNode(6);
    49         TreeNode t7 = new TreeNode(7);
    50         t1.left = t2;
    51         t1.right = t3;
    52         t2.left = t4;
    53         //t3.left = t5;
    54         //t3.right = t6;
    55         t2.right = t7;
    56         LCA sol = new LCA();
    57         TreeNode res = sol.LowestCommonAncestorOfDeepestLeaves(t1);
    58         System.out.println(res.val);
    59     }
    60 }

     

  • 相关阅读:
    [osg][原]自定义osgGA漫游器
    [osg]osg窗口显示和单屏幕显示
    sql中去除重复的数据 select distinct * from table
    Microsoft VBScript 运行时错误 错误 800a005e 无效使用 Null: Replace
    如何解决Access操作或事件已被禁用模式阻止
    sql 中 '' 与 null 的区别
    IsNull、rs、sum
    Access与SQL中的IsNull(),IS NULL的区别
    ASP将Table导出Excel
    ASP如何将table导出EXCEL表格
  • 原文地址:https://www.cnblogs.com/EdwardLiu/p/6551606.html
Copyright © 2011-2022 走看看