Skip to content

Commit 9c10648

Browse files
authored
Create 3sum.py
1 parent a497a84 commit 9c10648

File tree

1 file changed

+22
-0
lines changed

1 file changed

+22
-0
lines changed

Kangli/Arrays/3sum.py

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
class Solution(object):
2+
def threeSum(self, nums):
3+
res = []
4+
nums.sort()
5+
for i in xrange(len(nums)-2):
6+
if i > 0 and nums[i] == nums[i-1]:
7+
continue
8+
l, r = i+1, len(nums)-1
9+
while l < r:
10+
s = nums[i] + nums[l] + nums[r]
11+
if s < 0:
12+
l +=1
13+
elif s > 0:
14+
r -= 1
15+
else:
16+
res.append((nums[i], nums[l], nums[r]))
17+
while l < r and nums[l] == nums[l+1]:
18+
l += 1
19+
while l < r and nums[r] == nums[r-1]:
20+
r -= 1
21+
l += 1; r -= 1
22+
return res

0 commit comments

Comments
 (0)