二叉樹-最近的公共祖先

已知二叉樹,求二叉樹中給定的兩個(gè)節(jié)點(diǎn)的最近公共祖先。 最近公共祖先: 兩節(jié)點(diǎn)v與w的最近公共祖先u,滿足在樹上最低(離根最 遠(yuǎn)),且v,w兩個(gè)節(jié)點(diǎn)都是u的子孫。
LeetCode 236. Lowest Common Ancestor of a Binary Tree

思考與分析

1.兩個(gè)節(jié)點(diǎn)的公共祖先一定在從根節(jié)點(diǎn),至這兩個(gè)節(jié)點(diǎn)的路徑上。
2.由于求公共祖先中的最近公共祖先,那么即同時(shí)出現(xiàn)在這兩條路
徑上的離根節(jié)點(diǎn)最遠(yuǎn)的節(jié)點(diǎn)(或離兩個(gè)最近)。
3.最終算法即:求p節(jié)點(diǎn)路徑,q節(jié)點(diǎn)路徑,兩路徑上最后一個(gè)相同 的節(jié)點(diǎn)。



從根節(jié)點(diǎn)到某節(jié)點(diǎn)路徑(深度搜索)
1.從根節(jié)點(diǎn)遍歷(搜索)至該節(jié)點(diǎn),找到該節(jié)點(diǎn)后就結(jié)束搜索。
2.將遍歷過程中遇到的節(jié)點(diǎn)按照順序存儲(chǔ)起來(lái),這些節(jié)點(diǎn)即路徑節(jié)點(diǎn)。
前序遍歷(深度優(yōu)先)

void preorder(TreeNode *node, TreeNode *search){
    if(!node){
        return;
    }
    if(node == search){
        
    }
    preorder(node->left,search);
    preorder(node->right,search);
}
求根節(jié)點(diǎn)至某節(jié)點(diǎn)路徑
void preorder(TreeNode *node,TreeNode *search, std::vector<TreeNode*> &path,std::vector<TreeNode*> &result,int &finish)//node 正在遍歷節(jié)點(diǎn),search待搜索節(jié)點(diǎn),path 遍歷時(shí)節(jié)點(diǎn)路徑棧,result 最終搜索到節(jié)點(diǎn)search的路徑結(jié)果,finish 記錄是否找到節(jié)點(diǎn)search的遍歷,未找到時(shí)是0,找到為1{
    if(!node || finish){
    return;//當(dāng)node為空或已找到search 節(jié)點(diǎn)直接返回,結(jié)束搜索
     }
    path.push_back(node);//先序遍歷時(shí),將節(jié)點(diǎn)壓入path棧
    if(node == search){
        finish = 1;
        result = path;
    }
    preorder(node->left,search,path,result,finish);
    preorder(node->right,search,path,result,finish);
    path.pop_back();//結(jié)束遍歷node時(shí),將node節(jié)點(diǎn)彈出path棧

}

1.求出較短路徑的長(zhǎng)度n。
2.同時(shí)遍歷p節(jié)點(diǎn)的路徑與q節(jié)點(diǎn)的路徑,遍歷n個(gè)節(jié)點(diǎn),最后一個(gè)相同節(jié)點(diǎn),即最近 公共祖先。

class Solution{
public:
    TreeNode* lowestCommonAncestor(TreeNode * root, TreeNode *p ,TreeNode *q){
        std::vector<TreeNode*> path;申明遍歷用的臨時(shí)棧
        std::vector<TreeNode*> node_p_path;//儲(chǔ)存P節(jié)點(diǎn)路徑
        std::vector<TreeNode*>node_q_path;//儲(chǔ)存q節(jié)點(diǎn)路徑
        int finish = 0;//記錄是否完成搜索
        preorder(root, p,path,node_p_path,finish);
        path.clear();//清空path,finish,計(jì)算q節(jié)點(diǎn)路徑
        finish = 0;
        preorder(root, q, path,node_q_path,finish);
        int path_len = 0;
        if(node_p_path.size() < node_q_path.size()){
            path_len = node_p_path.size();
        }
        else{
            path_len = node_q_path.size();
        }
        TreeNode * result = 0;
        for (int i = 0; i < path_len; i++){
            if(node_p_path[i] = node_q_path[i]){
                result = node_p_path[i];
            }//最后相同的節(jié)點(diǎn)為最近公共節(jié)點(diǎn)
        }
        return result;
}
};
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 樹的概述 樹是一種非常常用的數(shù)據(jù)結(jié)構(gòu),樹與前面介紹的線性表,棧,隊(duì)列等線性結(jié)構(gòu)不同,樹是一種非線性結(jié)構(gòu) 1.樹的定...
    Jack921閱讀 4,753評(píng)論 1 31
  • 一. 尋找父親節(jié)點(diǎn)和孩子節(jié)點(diǎn) 首先需要回顧一下希爾伯特曲線的生成方式,具體代碼見筆者上篇文章的分析,在這個(gè)分析中,...
    一縷殤流化隱半邊冰霜閱讀 2,541評(píng)論 6 15
  • 什么是二叉樹? 引用自百度百科:在計(jì)算機(jī)科學(xué)中,二叉樹是每個(gè)節(jié)點(diǎn)最多有兩個(gè)子樹的樹結(jié)構(gòu)。通常子樹被稱作“左子樹”(...
    AnICoo1閱讀 1,471評(píng)論 0 1
  • 題量有點(diǎn)多,建議Ctrl + F題號(hào)或題目哦~ 二叉樹的遍歷(前序遍歷,中序遍歷,后序遍歷)[144] Binar...
    野狗子嗷嗷嗷閱讀 9,334評(píng)論 2 37
  • 今天早上出門時(shí),冷風(fēng)吹得我瑟瑟發(fā)抖,趕緊把敞開的深紅色繭型大衣緊緊裹在一起。走了幾步,發(fā)現(xiàn)雖然風(fēng)大,但陽(yáng)光也很“大...
    雁南秋閱讀 347評(píng)論 6 6

友情鏈接更多精彩內(nèi)容