-
Notifications
You must be signed in to change notification settings - Fork 265
/
Copy path018 4Sum.py
100 lines (87 loc) · 3.2 KB
/
018 4Sum.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
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
"""
Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = target? Find all unique
quadruplets in the array which gives the sum of target.
Note:
Elements in a quadruplet (a,b,c,d) must be in non-descending order. (ie, a <= b <= c <= d)
The solution set must not contain duplicate quadruplets.
For example, given array S = {1 0 -1 0 -2 2}, and target = 0.
A solution set is:
(-1, 0, 0, 1)
(-2, -1, 1, 2)
(-2, 0, 0, 2)
"""
__author__ = 'Danyang'
class Solution:
def fourSum_TLE(self, num, target):
"""
Algorithm: pointers
O(n^3) typically, O(n^(k-1))
Similar algorithm as 014 3Sum
Notice:
Algorithm able to pass in Java or C++, but not Python
:param num: array
:return: a list of lists of length 3, [[val1,val2,val3]]
"""
# record result
result = []
num.sort()
length = len(num)
h = 0
while h<length-3:
i = h+1
while i<length-2:
j = i+1
k = length-1
while j<k:
lst = [num[h], num[i], num[j], num[k]]
summation = sum(lst)
if summation==target:
result.append(lst)
k -= 1
j += 1
# remove duplicate
while j<k and num[j]==num[j-1]:
j += 1
while j<k and num[k]==num[k+1]:
k -= 1
elif summation>target:
k -= 1
else:
j += 1
i += 1
# Jump, remove duplicate
while i<length-2 and num[i]==num[i-1]:
i += 1
h += 1
# Jump, remove duplicate
while h<length-3 and num[h]==num[h-1]:
h += 1
return result
def fourSum(self, num, target):
"""
Algorithm: Hash Table
O(n^2)
:param num: array
:param target: int
:return: a list of lists of length 4, [[val1,val2,val3,val4]]
"""
length, result_set, sum2index = len(num), set(), {}
if length<4:
return []
num.sort()
for p in xrange(length):
for q in xrange(p+1, length):
# record the pair sum
if num[p]+num[q] not in sum2index:
sum2index[num[p]+num[q]] = [(p, q)]
else:
sum2index[num[p]+num[q]].append((p, q))
for i in xrange(length):
for j in xrange(i+1, length-2):
sum_remain = target-num[i]-num[j]
if sum_remain in sum2index:
# construct the result
for pair in sum2index[sum_remain]:
if pair[0]>j: # avoid duplicate
result_set.add(( num[i], num[j], num[pair[0]], num[pair[1]] ))
return [list(i) for i in result_set] # convert tuple to list