-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path1110.py
More file actions
43 lines (41 loc) · 1.4 KB
/
1110.py
File metadata and controls
43 lines (41 loc) · 1.4 KB
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
# Definition for a binary tree node.
# class TreeNode(object):
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution(object):
def delNodes(self, root, to_delete):
"""
:type root: TreeNode
:type to_delete: List[int]
:rtype: List[TreeNode]
"""
if not root or to_delete==[]:
return root
delete = set(to_delete)
ans = []
self.postorder(root, None, delete, ans)
return ans
def postorder(self, node, pre, delete, ans):
if node.val in delete:
delete.remove(node.val)
if node.left:
self.postorder(node.left, None, delete, ans)
if node.right:
self.postorder(node.right, None, delete, ans)
else:
if pre == None:
ans.append(node)
if node.left and node.left.val in delete:
p = node.left
node.left = None
self.postorder(p, None, delete, ans)
elif node.left:
self.postorder(node.left, node, delete, ans)
if node.right and node.right.val in delete:
p = node.right
node.right = None
self.postorder(p, None, delete, ans)
elif node.right:
self.postorder(node.right, node, delete, ans)