-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path3. 3SumLeet.py
44 lines (35 loc) · 1.08 KB
/
3. 3SumLeet.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
class Solution:
def threeSum(self, nums: [int]) -> [[int]]:
res = set()
# Spliting
n, p, z = [], [], []
for i in nums:
if i>0:
p.append(i)
elif i<0:
n.append(i)
else:
z.append(i)
N, P = set(n), set(p)
# Case1: p, 1z, n
if z:
for num in P:
if -1*num in N:
res.add((-1*num, 0, num))
# Case2: 0, 0, 0
if len(z)>=3:
res.add((0,0,0))
# Case 3: 2 negatives == 1 positive
for i in range(len(n)):
for j in range(i+1, len(n)):
t = -1*(n[i] + n[j])
if t in P:
res.add(tuple(sorted([n[i], n[j], t])))
# Case 4: 2 positive == 1 negative
for i in range(len(p)):
for j in range(i+1, len(p)):
t = -1*(p[i] + p[j])
if t in N:
res.add(tuple(sorted([p[i], p[j], t])))
return res
# Link: https://leetcode.com/problems/3sum/