-
Notifications
You must be signed in to change notification settings - Fork 460
/
Three_Number_Sum.py
28 lines (25 loc) · 939 Bytes
/
Three_Number_Sum.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
# https://www.algoexpert.io/questions/Three%20Number%20Sum
# O(n^2) time | O(n) space
def three_number_sum(array, targetSum):
array.sort()
triplates = []
for i in range(len(array) - 2):
left_index = i + 1
right_index = len(array) - 1
while left_index < right_index:
sum = array[i] + array[left_index] + array[right_index]
if sum == targetSum:
triplates.append(array[i])
triplates.append(array[left_index])
triplates.append(array[right_index])
left_index += 1
right_index -= 1
elif sum < targetSum:
left_index += 1
elif sum > targetSum:
right_index -= 1
return triplates
sample_input_array = [12, 3, 1, 2, -6, 5, -8, 6]
sample_sum = 0
result = three_number_sum(sample_input_array, sample_sum)
print("The sets of triplates are: ", result)