-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathQuestion 30
118 lines (60 loc) · 2.01 KB
/
Question 30
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
You are given a binary tree in which each node contains an integer value.Find the number of paths that sum to a given value.The path does not need to start or end at the root or a leaf, but it must go downwards (traveling only from parent nodes to child nodes).
The tree has no more than 1,000 nodes and the values are in the range -1,000,000 to 1,000,000.
root = [10,5,-3,3,2,None,11,3,-2,None,1], sum = 8
10
/ \
5 -3
/ \ \
3 2 11
/ \ \
3 -2 1
Return 3. The paths that sum to 8 are:
1. 5 -> 3
2. 5 -> 2 -> 1
3. -3 -> 11
def spilt_array(input_matrix, sum_first_element, array, a):
if sum_first_element == len(input_matrix):
array.append(input_matrix)
return
left=input_matrix[:sum_first_element]
right=input_matrix[:sum_first_element]
a=1
ele_left=a
ele_right=a
for i in input_matrix[sum_first_element:]:
if i==None:
i=0
if ele_left==0 and ele_right==0:
a*=2
ele_left=a
ele_right=a
if ele_left==0 and ele_right>0:
right.append(i)
ele_right-=1
if ele_left>0:
left.append(i)
ele_left-=1
spilt_array(left, sum_first_element+1, array, a)
spilt_array(right, sum_first_element+1, array, a)
return array
def sum_tree(input_matrix,sum_val):
array=[]
a=1
sum_first_element = 1
result = []
all_paths = spilt_array(input_matrix, sum_first_element, array, a)
for i in all_paths:
if sum(i[1:-1]) == sum_val:
if i[1:-1] not in result:
result.append(i[1:-1])
if sum(i[:-1]) == sum_val:
if i[:-1] not in result:
result.append(i[:-1])
if sum(i[1:]) == sum_val:
if i[1:] not in result:
result.append(i[1:])
return len(result)
if __name__ == "__main__":
input_matrix = [10,5,-3,3,2,None,11,3,-2,None,1]
sum_val = 8
print(sum_tree(input_matrix,sum_val))