给你一个有根节点 root
的二叉树,返回它 最深的叶节点的最近公共祖先 。
回想一下:
0
,如果某一节点的深度为 d
,那它的子节点的深度就是 d+1
A
是一组节点 S
的 最近公共祖先,S
中的每个节点都在以 A
为根节点的子树中,且 A
的深度达到此条件下可能的最大值。输入:root = [3,5,1,6,2,0,8,null,null,7,4] 输出:[2,7,4] 解释:我们返回值为 2 的节点,在图中用黄色标记。 在图中用蓝色标记的是树的最深的节点。 注意,节点 6、0 和 8 也是叶节点,但是它们的深度是 2 ,而节点 7 和 4 的深度是 3 。
输入:root = [1] 输出:[1] 解释:根节点是树中最深的节点,它是它本身的最近公共祖先。
输入:root = [0,1,3,null,2] 输出:[2] 解释:树中最深的叶节点是 2 ,最近公共祖先是它自己。
[1, 1000]
的范围内。0 <= Node.val <= 1000
- /**
- * Definition for a binary tree node.
- * struct TreeNode {
- * int val;
- * TreeNode *left;
- * TreeNode *right;
- * TreeNode(int x) : val(x), left(NULL), right(NULL) {}
- * };
- */
- class Solution {
- public:
- TreeNode* dfs(TreeNode* curr,int& depth){
- if(curr==NULL)
- return NULL;
- depth++;
- int l_depth = depth;
- int r_depth = depth;
- TreeNode* left = dfs(curr->left,l_depth);
- TreeNode* right = dfs(curr->right,r_depth);
- depth = max(l_depth,r_depth);
- if(l_depth==r_depth){
- return curr;
- }
- if(l_depth>r_depth){
- return left;
- }
- return right;
-
- }
- TreeNode* lcaDeepestLeaves(TreeNode* root) {
- int depth = 0;
- return dfs(root,depth);
- }
- };