-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path04_Lowest_Common_Ancestor_of_Deepest_Leaves.cpp
74 lines (54 loc) · 2.22 KB
/
04_Lowest_Common_Ancestor_of_Deepest_Leaves.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
// 1123. Lowest Common Ancestor of Deepest Leaves
// Given the root of a binary tree, return the lowest common ancestor of its deepest leaves.
// Recall that:
// The node of a binary tree is a leaf if and only if it has no children
// The depth of the root of the tree is 0. if the depth of a node is d, the depth of each of its children is d + 1.
// The lowest common ancestor of a set S of nodes, is the node A with the largest depth such that every node in S is in the subtree with root A.
// Example 1:
// Input: root = [3,5,1,6,2,0,8,null,null,7,4]
// Output: [2,7,4]
// Explanation: We return the node with value 2, colored in yellow in the diagram.
// The nodes coloured in blue are the deepest leaf-nodes of the tree.
// Note that nodes 6, 0, and 8 are also leaf nodes, but the depth of them is 2, but the depth of nodes 7 and 4 is 3.
// Example 2:
// Input: root = [1]
// Output: [1]
// Explanation: The root is the deepest node in the tree, and it's the lca of itself.
// Example 3:
// Input: root = [0,1,3,null,2]
// Output: [2]
// Explanation: The deepest leaf node in the tree is 2, the lca of one node is itself.
// Constraints:
// The number of nodes in the tree will be in the range [1, 1000].
// 0 <= Node.val <= 1000
// The values of the nodes in the tree are unique.
class Solution
{
public:
pair<int, TreeNode *> helper(TreeNode *node)
{
if (!node)
return {0, nullptr};
auto left = helper(node->left);
auto right = helper(node->right);
if (left.first == right.first)
return {left.first + 1, node};
else if (left.first > right.first)
return {left.first + 1, left.second};
else
return {right.first + 1, right.second};
}
TreeNode *lcaDeepestLeaves(TreeNode *root)
{
return helper(root).second;
}
};
/*
1. Traverse the tree recursively.
2. At each node, compute the depth and LCA of the left and right subtrees.
3. If the depths are equal, the current node is the LCA.
4. Otherwise, return the LCA from the deeper subtree.
5. The final result is the LCA from the root node.
Time Complexity: O(N), where N is the number of nodes in the tree.
Space Complexity: O(H), where H is the height of the tree.
*/