leetcode<236. 二叉树的最近公共祖先>

简介: 二叉树编程题解析

image.png

传送门:236. 二叉树的最近公共祖先

题目给我们一棵树以及树上的两个节点。要我们求两个节点的最近公共祖先。什么叫祖先呢,只要是与这个节点的有血缘关系的父节点,包括其自身都可以称作这个节点的祖先。而要我们求节点的最近公共祖先,不由得让人想到用找两个树时的路径进行对比。若分别找到二者的路径,则这个问题便演变成了找两个链表交点的问题。

现在的主要问题就是该如何找节点的路径?不妨使用DFS算法进行实现,用栈进行存储。由于DFS会不断深入和回溯,每次走错路就将之前的路径出栈,否则便继续深入,直到找到目标节点为止。最后用两个栈进行查找第一个相同的节点便可以解决问题。

bool getpath(TreeNode* root,TreeNode* x,stack<TreeNode*>& path)
    {
        if(root == nullptr) return false;           //走到空节点即找不到返回失败
        path.push(root);                            //走到新节点就先入栈
        if(root == x) return true;                  //找到目标节点返回成功
        if(getpath(root->left,x,path))              //判断往左找是否成功
        {
            return true;
        }
        if(getpath(root->right,x,path))             //判断往右找是否成功
        {
            return true;
        }
        path.pop();                                 //出栈
        return false;                               //都没有就返回失败
    }
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        stack<TreeNode*> ppath,qpath;          //定义两个栈用于存储路径
        getpath(root,p,ppath);                 //求p的路径
        getpath(root,q,qpath);                 //求q的路径
        while(ppath.size()!= qpath.size())    
        {
            if(ppath.size()>qpath.size())      //把长的部分去掉使得两个栈一样长
            {
                ppath.pop();
            }
            else
            {
                qpath.pop();
            }
        }
        while(ppath.top()!=qpath.top())        //找第一个相同节点
        {
            ppath.pop();
            qpath.pop();
        }
        return ppath.top();
    }

image.gif

目录
相关文章
|
1月前
【LeetCode 31】104.二叉树的最大深度
【LeetCode 31】104.二叉树的最大深度
19 2
|
1月前
【LeetCode 29】226.反转二叉树
【LeetCode 29】226.反转二叉树
15 2
|
1月前
【LeetCode 28】102.二叉树的层序遍历
【LeetCode 28】102.二叉树的层序遍历
14 2
|
1月前
【LeetCode 43】236.二叉树的最近公共祖先
【LeetCode 43】236.二叉树的最近公共祖先
17 0
|
1月前
【LeetCode 38】617.合并二叉树
【LeetCode 38】617.合并二叉树
13 0
|
1月前
【LeetCode 37】106.从中序与后序遍历构造二叉树
【LeetCode 37】106.从中序与后序遍历构造二叉树
12 0
|
1月前
【LeetCode 34】257.二叉树的所有路径
【LeetCode 34】257.二叉树的所有路径
11 0
|
1月前
【LeetCode 32】111.二叉树的最小深度
【LeetCode 32】111.二叉树的最小深度
15 0
|
3月前
|
存储 算法
二叉树进阶-学会层序遍历助你一次刷完leetcode10道题
文章深入探讨了二叉树的层序遍历方法,并展示了如何通过队列实现层序遍历的算法逻辑,同时指出掌握层序遍历技巧可以帮助解决LeetCode上的多道相关题目。
二叉树进阶-学会层序遍历助你一次刷完leetcode10道题
|
3月前
|
算法 Java
LeetCode第94题二叉树的中序遍历
文章介绍了LeetCode第94题"二叉树的中序遍历"的解法,使用递归实现了中序遍历的过程,遵循了"左根右"的遍历顺序,并提供了清晰的Java代码实现。
LeetCode第94题二叉树的中序遍历