474.最近公共祖先II

描述

給一棵二叉樹(shù)和二叉樹(shù)中的兩個(gè)節(jié)點(diǎn)域滥,找到這兩個(gè)節(jié)點(diǎn)的最近公共祖先 LCA纵柿。兩個(gè)節(jié)點(diǎn)的最近公共祖先,是指兩個(gè)節(jié)點(diǎn)的所有父親節(jié)點(diǎn)中(包括這兩個(gè)節(jié)點(diǎn))启绰,離這兩個(gè)節(jié)點(diǎn)最近的公共的節(jié)點(diǎn)昂儒。每個(gè)節(jié)點(diǎn)除了左右兒子指針以外,還包含一個(gè)父親指針parent委可,指向自己的父親渊跋。

樣例

對(duì)于下面的這棵二叉樹(shù)

          4
         / \
        3   7
           / \
          5   6
    LCA(3, 5) = 4
    LCA(5, 6) = 7
    LCA(6, 7) = 7

代碼

/**
 * Definition of ParentTreeNode:
 * 
 * class ParentTreeNode {
 *     public ParentTreeNode parent, left, right;
 * }
 */

public class Solution {
    /**
     * @param root: The root of the tree
     * @param A, B: Two node in the tree
     * @return: The lowest common ancestor of A and B
     */
    public ParentTreeNode lowestCommonAncestorII(ParentTreeNode root,
                                                 ParentTreeNode A,
                                                 ParentTreeNode B) {
        // 用數(shù)組分別存儲(chǔ) A , B 結(jié)點(diǎn)向上尋找的結(jié)點(diǎn)
        ArrayList<ParentTreeNode> pathA = getPath2Root(A);
        ArrayList<ParentTreeNode> pathB = getPath2Root(B);
        
        // 忘記 -1 會(huì)出現(xiàn)數(shù)組下標(biāo)越界
        int indexA = pathA.size() - 1;
        int indexB = pathB.size() - 1;
        
        ParentTreeNode lowestAncestor = null;
        // 從最遠(yuǎn)的公共祖先開(kāi)始尋找,找到最近的公共祖先
        while (indexA >= 0 && indexB >= 0) {
            // break 時(shí)不需要更新 lowestAncestor撤缴,
            // 其上一個(gè) pathA.get(indexA) == pathB.get(indexB) 的 lowestAncestor 是所需的
            if (pathA.get(indexA) != pathB.get(indexB)) {
                break;
            }
            lowestAncestor = pathA.get(indexA);
            indexA--;
            indexB--;
        }
        
        return lowestAncestor;
    }
    
    private ArrayList<ParentTreeNode> getPath2Root(ParentTreeNode node) {
        ArrayList<ParentTreeNode> path = new ArrayList<>();
        while (node != null) {
            path.add(node);
            node = node.parent;
        }
        return path;
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末刹枉,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子屈呕,更是在濱河造成了極大的恐慌微宝,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件虎眨,死亡現(xiàn)場(chǎng)離奇詭異蟋软,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)嗽桩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門(mén)岳守,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人碌冶,你說(shuō)我怎么就攤上這事湿痢。” “怎么了扑庞?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵譬重,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我罐氨,道長(zhǎng)臀规,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任栅隐,我火速辦了婚禮塔嬉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘租悄。我一直安慰自己谨究,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布恰矩。 她就那樣靜靜地躺著记盒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪外傅。 梳的紋絲不亂的頭發(fā)上纪吮,一...
    開(kāi)封第一講書(shū)人閱讀 51,292評(píng)論 1 301
  • 那天俩檬,我揣著相機(jī)與錄音,去河邊找鬼碾盟。 笑死棚辽,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的冰肴。 我是一名探鬼主播屈藐,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼熙尉!你這毒婦竟也來(lái)了联逻?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤检痰,失蹤者是張志新(化名)和其女友劉穎包归,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體铅歼,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡公壤,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了椎椰。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片厦幅。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖慨飘,靈堂內(nèi)的尸體忽然破棺而出确憨,到底是詐尸還是另有隱情,我是刑警寧澤瓤的,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布缚态,位于F島的核電站,受9級(jí)特大地震影響堤瘤,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜浆熔,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一本辐、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧医增,春花似錦慎皱、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至忽刽,卻和暖如春天揖,著一層夾襖步出監(jiān)牢的瞬間夺欲,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工今膊, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留些阅,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓斑唬,卻偏偏與公主長(zhǎng)得像市埋,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子恕刘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 樹(shù)的概述 樹(shù)是一種非常常用的數(shù)據(jù)結(jié)構(gòu)缤谎,樹(shù)與前面介紹的線性表,棧褐着,隊(duì)列等線性結(jié)構(gòu)不同坷澡,樹(shù)是一種非線性結(jié)構(gòu) 1.樹(shù)的定...
    Jack921閱讀 4,452評(píng)論 1 31
  • 最近公共祖先I 描述: 給定一棵二叉樹(shù),找到兩個(gè)節(jié)點(diǎn)的最近公共父節(jié)點(diǎn) (LCA)献起。最近公共祖先是兩個(gè)節(jié)點(diǎn)的公共的祖...
    lyoungzzz閱讀 419評(píng)論 0 0
  • 一. 尋找父親節(jié)點(diǎn)和孩子節(jié)點(diǎn) 首先需要回顧一下希爾伯特曲線的生成方式洋访,具體代碼見(jiàn)筆者上篇文章的分析,在這個(gè)分析中谴餐,...
    一縷殤流化隱半邊冰霜閱讀 2,430評(píng)論 6 15
  • 介紹 從一個(gè)有根樹(shù)中尋找一對(duì)節(jié)點(diǎn)的最小公共祖先(Lowest common ancestor)的問(wèn)題姻政,從20世紀(jì)就...
    HITMiner閱讀 1,580評(píng)論 0 2
  • 說(shuō)兩件小事厌殉,都是昨天早上發(fā)生的食绿。 第一件事。 昨天早上公罕,當(dāng)我上了一輛出租車器紧,準(zhǔn)備告訴司機(jī)去哪里的時(shí)候,卻被司機(jī)告知...
    虛舟老師閱讀 1,287評(píng)論 4 3