給定一個二叉樹, 找到該樹中兩個指定節(jié)點的最近公共祖先。
創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設,通州企業(yè)網(wǎng)站建設,通州品牌網(wǎng)站建設,網(wǎng)站定制,通州網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,通州網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
百度百科中最近公共祖先的定義為:“對于有根樹 T 的兩個結點 p、q,最近公共祖先表示為一個結點 x,滿足 x 是 p、q 的祖先且 x 的深度盡可能大(一個節(jié)點也可以是它自己的祖先)?!?/p>
例如,給定如下二叉樹: root = [3,5,1,6,2,0,8,null,null,7,4]
示例 1:
輸入: root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 1
輸出: 3
解釋: 節(jié)點 5 和節(jié)點 1 的最近公共祖先是節(jié)點 3。
示例 2:
輸入: root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 4
輸出: 5
解釋: 節(jié)點 5 和節(jié)點 4 的最近公共祖先是節(jié)點 5。因為根據(jù)定義最近公共祖先節(jié)點可以為節(jié)點本身。
說明:
所有節(jié)點的值都是唯一的。
p、q 為不同節(jié)點且均存在于給定的二叉樹中。
從根節(jié)點往下遍歷,如果當前節(jié)點==p或者q,那么直接返回(從上往下找的第一個符合的點必是兩點的父親)。如果當前節(jié)點的左子樹里有符合條件的點,并且當前節(jié)點的右子樹也有符合條件的點,那么返回當前節(jié)點。如果兩個節(jié)點的lca出現(xiàn)在左子樹或者右子樹的一個,那么返回在那個子樹找到的結果即可。
時間復雜度O(n),空間復雜度O(n)。
遞歸很簡單。
非遞歸使用一個HashMap存儲每個節(jié)點和父親節(jié)點的映射,通過找到p和q的父親節(jié)點,再把p到根節(jié)點的路徑上的點加入到Set中,最后讓q往上爬,找q和p最早相同的節(jié)點。
遞歸:
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
if(root==null||root==p||root==q){
return root;
}
TreeNode l=lowestCommonAncestor(root.left,p,q);
TreeNode r=lowestCommonAncestor(root.right,p,q);
if(l!=null&&r!=null){
return root;
}
if(l==null) return r;
return l;
}
}
非遞歸:
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
Map fa=new HashMap<>();
fa.put(root,null);
Stack st=new Stack<>();
st.add(root);
while(!fa.containsKey(p)||!fa.containsKey(q)){
TreeNode cur=st.pop();
if(cur.left!=null){
st.add(cur.left);
fa.put(cur.left,cur);
}
if(cur.right!=null){
st.add(cur.right);
fa.put(cur.right,cur);
}
}
Set set=new HashSet<>();
while(p!=null){
set.add(p);
p=fa.get(p);
}
while(!set.contains(q)){
q=fa.get(q);
}
return q;
}
}