思路:给定节点P,Q。
1、特殊情况下:P,Q为根节点或者树为空,那么直接返回根节点。
2、三种情况:对左子树和右子树分别递归。
递归后返回的左树和右树节点返回值都不为0,说明根节点就是最近公共祖先
递归后,左树为nullptr,说明P,Q都在右树上,那么递归后右节点就是最近公共祖先
递归后,右树为nullptr,说明P,Q都在左树上,那么递归后右节点就是最近公共祖先
class Solution {
public:
TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
if(root == nullptr || root == p || root == q) return root;
TreeNode* left=lowestCommonAncestor(root->left,p,q);
TreeNode* right=lowestCommonAncestor(root->right,p,q);
if(left!=NULL&&right!=NULL) return root;
else if(left!=NULL) return left;
else if(right!=NULL) return right;
return nullptr;
}
};
该博客介绍了如何在二叉树中找到两个指定节点的最近公共祖先。通过递归策略,分别检查左子树和右子树,当左右子树的递归结果都不为null时,当前节点即为最近公共祖先;若左子树不为null,则公共祖先在左子树;反之在右子树。此算法适用于二叉树数据结构的问题解决。
&spm=1001.2101.3001.5002&articleId=124163893&d=1&t=3&u=4a11c24b6dd94b28a0d0b16455c2f7c2)
449

被折叠的 条评论
为什么被折叠?



