Skip to content

Commit a57bc97

Browse files
author
weiy
committed
hard binary tree maximum path sum
1 parent b3f287c commit a57bc97

File tree

2 files changed

+165
-145
lines changed

2 files changed

+165
-145
lines changed

Tree/BinarySearchTree.py

-145
This file was deleted.

Tree/BinaryTreeMaximumPathSum.py

+165
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,165 @@
1+
"""
2+
Given a non-empty binary tree, find the maximum path sum.
3+
4+
For this problem, a path is defined as any sequence of nodes from some starting node to any node in the tree along the parent-child connections. The path must contain at least one node and does not need to go through the root.
5+
6+
Example 1:
7+
8+
Input: [1,2,3]
9+
10+
1
11+
/ \
12+
2 3
13+
14+
Output: 6
15+
Example 2:
16+
17+
Input: [-10,9,20,null,null,15,7]
18+
19+
-10
20+
/ \
21+
9 20
22+
/ \
23+
15 7
24+
25+
Output: 42
26+
27+
给定一棵树:
28+
找到一条路径,该路径所经过的节点之和是此树中最大的。
29+
30+
测试用例:
31+
https://leetcode.com/problems/binary-tree-maximum-path-sum/description/
32+
"""
33+
34+
35+
"""
36+
第一版:
37+
此版本实现思路:
38+
从底到顶,每次都会比对是否是最大值。
39+
此版本的问题是输出的不是最大的路径而是所有节点中最大的相加和。
40+
比如此树:
41+
5
42+
/ \
43+
4 8
44+
/ / \
45+
11 13 4
46+
/ \ \
47+
7 2 1
48+
49+
从全部相加得出的是 55,而测试要求是48。
50+
测试中所定义的*路径*是一条连通的线,可以 7 -> 11 -> 2,但不能 7 -> 11 -> 2 -> 4
51+
52+
# Definition for a binary tree node.
53+
# class TreeNode(object):
54+
# def __init__(self, x):
55+
# self.val = x
56+
# self.left = None
57+
# self.right = None
58+
59+
class Solution(object):
60+
def maxPathSum(self, root):
61+
'''
62+
:type root: TreeNode
63+
:rtype: int
64+
'''
65+
self.maxes = -float('inf')
66+
67+
def helper(root):
68+
myValue = root.val
69+
70+
if not root.left and not root.right:
71+
self.maxes = myValue if myValue > self.maxes else self.maxes
72+
return myValue
73+
74+
if root.left:
75+
value = helper(root.left)
76+
if value > 0:
77+
myValue += value
78+
if myValue < value:
79+
self.maxes = value if value > self.maxes else self.maxes
80+
else:
81+
self.maxes = myValue if myValue > self.maxes else self.maxes
82+
83+
if root.right:
84+
value = helper(root.right)
85+
86+
87+
if value > 0:
88+
myValue += value
89+
90+
if myValue < value:
91+
self.maxes = value if value > self.maxes else self.maxes
92+
else:
93+
self.maxes = myValue if myValue > self.maxes else self.maxes
94+
return myValue
95+
96+
helper(root)
97+
98+
return self.maxes
99+
100+
"""
101+
"""
102+
Passed! And Beat 94.66%.
103+
第二版思路:
104+
105+
每一个点有两种决策:
106+
107+
1. 以此点为中转站的 left to right 的值,此值确定的是以此点为轴心的局部范围内是否有最大值。
108+
1
109+
/ \
110+
2 3
111+
112+
2. 向上返回的值。此值确定的是以父节点为轴心的局部范围是否有最大值。
113+
例子:
114+
10
115+
/ \
116+
11 -20
117+
/ \
118+
15 5
119+
120+
在-20这个点它要向上返回的值是 15 -> -20 这一条线。
121+
以-20为轴心的值是 15 -> -20 -> 5
122+
123+
1.中要进行的判断是,left + val + right, left + val, right + val, val 和 已记录的最大值哪个最大。4
124+
2.要一直返回,返回之后的判断与1一致,2要返回的内容是 val, left + val和right + val 最大的那个。
125+
最后叶节点比对下最大值直接返回即可。
126+
"""
127+
# Definition for a binary tree node.
128+
# class TreeNode(object):
129+
# def __init__(self, x):
130+
# self.val = x
131+
# self.left = None
132+
# self.right = None
133+
134+
class Solution(object):
135+
def maxPathSum(self, root):
136+
'''
137+
:type root: TreeNode
138+
:rtype: int
139+
'''
140+
self.maxes = -float('inf')
141+
142+
def helper(root):
143+
myValue = root.val
144+
if not root.left and not root.right:
145+
self.maxes = myValue if myValue > self.maxes else self.maxes
146+
return myValue
147+
148+
valueLeft, valueRight = -float('inf'), -float('inf')
149+
150+
if root.left:
151+
valueLeft = helper(root.left)
152+
153+
if root.right:
154+
valueRight = helper(root.right)
155+
156+
# judge left to right is max or not.
157+
158+
self.maxes = max([myValue + valueLeft, myValue + valueRight, myValue + valueLeft + valueRight, myValue, self.maxes])
159+
160+
# return to parent
161+
return max(myValue + max(valueLeft, valueRight), myValue)
162+
163+
helper(root)
164+
return self.maxes
165+

0 commit comments

Comments
 (0)