forked from shuboc/LeetCode-2
-
Notifications
You must be signed in to change notification settings - Fork 1
/
smallest-subtree-with-all-the-deepest-nodes.py
59 lines (53 loc) · 1.77 KB
/
smallest-subtree-with-all-the-deepest-nodes.py
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
# Time: O(n)
# Space: O(h)
# Given a binary tree rooted at root, the depth of each node is
# the shortest distance to the root.
# A node is deepest if it has the largest depth possible among
# any node in the entire tree.
# The subtree of a node is that node, plus the set of all descendants
# of that node.
# Return the node with the largest depth such that it contains
# all the deepest nodes in it's subtree.
#
# Example 1:
#
# Input: [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 colored in blue are the deepest nodes of the tree.
# The input "[3, 5, 1, 6, 2, 0, 8, null, null, 7, 4]" is
# a serialization of the given tree.
# The output "[2, 7, 4]" is a serialization of the subtree
# rooted at the node with value 2.
# Both the input and output have TreeNode type.
#
# Note:
# - The number of nodes in the tree will be between 1 and 500.
# - The values of each node are unique.
#
# Definition for a binary tree node.
# class TreeNode(object):
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
import collections
class Solution(object):
def subtreeWithAllDeepest(self, root):
"""
:type root: TreeNode
:rtype: TreeNode
"""
Result = collections.namedtuple("Result", ("node", "depth"))
def dfs(node):
if not node:
return Result(None, 0)
left, right = dfs(node.left), dfs(node.right)
if left.depth > right.depth:
return Result(left.node, left.depth+1)
if left.depth < right.depth:
return Result(right.node, right.depth+1)
return Result(node, left.depth+1)
return dfs(root).node