2014-09-30 69 views
-1

我想了解破解編碼採訪頁面129中的解決方案之一。這是關於找到最低的共同祖先。請參閱下面的代碼。我的問題是在評論最低的共同祖先破解代碼採訪解決方案

總之,我的問題是:

1)這行代碼:

if(root.left == p || root.left == q) return root.left; 

爲什麼返回root.left而不是根?

2)對於這些代碼:

else if (nodesFromLeft == ONE_NODE_FOUND) { 
    if (root == p) return p; 
    else if (root == q) return q; 
    } 

爲什麼回報p如果根== P,這是怎麼祖先?同樣適用於q。

這裏是低於整個代碼:

static int TWO_NODES_FOUND = 2; 
static int ONE_NODE_FOUND = 1; 
static int NO_NODES_FOUND = 0; 

// Checks how many 「special」 nodes are located under this root 
int covers(TreeNode root, TreeNode p, TreeNode q) { 

     int ret = NO_NODES_FOUND; 
     if (root == null) return ret; 
     if (root == p || root == q) ret += 1; 
     ret += covers(root.left, p, q); 
     if(ret == TWO_NODES_FOUND) // Found p and q 
      return ret; 
return ret + covers(root.right, p, q); 
} 

TreeNode commonAncestor(TreeNode root, TreeNode p, TreeNode q) { 
     if (q == p && (root.left == q || root.right == q)) return root; 

     int nodesFromLeft = covers(root.left, p, q); // Check left side 
     if (nodesFromLeft == TWO_NODES_FOUND) { 
      if(root.left == p || root.left == q) return root.left;//Qn1:See above 
     else return commonAncestor(root.left, p, q); 
     } 
     else if (nodesFromLeft == ONE_NODE_FOUND) { 
      if (root == p) return p; //Qn 2: See qn above 
      else if (root == q) return q; //Qn2: See qn above 
     } 
     int nodesFromRight = covers(root.right, p, q); // Check right side 
     if(nodesFromRight == TWO_NODES_FOUND) { 
      if(root.right == p || root.right == q) return root.right; 
     else return commonAncestor(root.right, p, q); 
     } 
     else if (nodesFromRight == ONE_NODE_FOUND) { 
      if (root == p) return p; 
      else if (root == q) return q; 
     } 
     if (nodesFromLeft == ONE_NODE_FOUND && nodesFromRight == ONE_NODE_FOUND) return root; 

     else return null; 
} 
+0

'我的問題在評論中':不要把它們放在代碼中,明確地提出你的問題來明確你的問題。 – 2014-09-30 11:51:31

+0

好的,對不起。已經改進了代碼,並在代碼之外用粗體提出了問題,並在代碼中留下了我不清楚的代碼。 – stretchr 2014-09-30 12:19:36

回答

1

爲什麼返回root.left而不是根?

nodesFromLeft是2時,那麼兩個pqroot.left下。 如果其中之一是root.left那麼這是共同的祖先。一種是root.left ,另一種是低於它。

爲什麼返回p如果root == p,這個祖先怎麼樣?

nodesFromLeft是1,則一個節點是root.left下,另一個是 要麼rootroot.right下,或者不存在於樹存在。如果它是root, 那麼這就是祖先。一個不是root,另一個是在左邊。

在最後兩行檢查它在root.right下或不在樹中的情況。

+0

當你說'如果他們中的一個是root.left,那麼這就是共同的祖先',我在當前的理解方面存在差異,因爲如果其中一個是root.left,另一個是root.left,它應該不是'root '那是共同的祖先? – stretchr 2014-09-30 12:48:14

+0

@stretchr一個節點可以將自己作爲一個祖先,所以我們不需要升級。 http://en.wikipedia.org/wiki/Lowest_common_ancestor的第一段描述了這種情況:「如果v與w有直接連接,w是最低的共同祖先」 – fgb 2014-09-30 16:20:06

+0

我看到了,明白了。不知道一個節點可以自己作爲祖先。這澄清很多,謝謝! – stretchr 2014-09-30 23:59:00