-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy path四数之和.py
64 lines (57 loc) · 4.09 KB
/
四数之和.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
class Solution:
def __init__(self):
self.res = []
def fourSum(self, nums, target):
"""
:type nums: List[int]
:type target: int
:rtype: List[List[int]]
"""
if not nums:
return []
nums.sort()
n = len(nums)
for i in range(n-3):
# 跳过相同的数字
if i and nums[i] == nums[i - 1]:
continue
# 当连续4个数相加大于target时,说明已经大了,没必要继续循环
if nums[i] + nums[i + 1] + nums[i + 2] + nums[i + 3] > target:
break
# 当nums[i]和最后3个数相加小于target时,说明4sum-target<0,此时需要让nums[i]变大。
if nums[i] + nums[n - 3] + nums[n - 2] + nums[n - 1] < target:
continue
# 进入三数相加
self.threeSum(nums, target, i, n)
return self.res
def threeSum(self, nums, target, oldnum, n):
for i in range(oldnum + 1, n - 2):
if i > oldnum + 1 and nums[i] == nums[i - 1]:
continue
if nums[oldnum] + nums[i] + nums[i + 1] + nums[i + 2] > target:
break
if nums[oldnum] + nums[i] + nums[n - 2] + nums[n - 1] < target:
continue
left, right = i + 1, n - 1
while left < right:
temp = nums[i] + nums[left] + nums[right] + nums[oldnum] - target
if temp > 0:
# 跳过重复的数字
while left < right and nums[right] == nums[right-1]:
right -= 1
right -= 1
elif temp < 0:
while left < right and nums[left] == nums[left + 1]:
left += 1
left += 1
else:
self.res.append([nums[oldnum], nums[i], nums[left], nums[right]])
while left < right and nums[right] == nums[right - 1]:
right -= 1
right -= 1
while left < right and nums[left] == nums[left + 1]:
left += 1
left += 1
nums = [91277418,66271374,38763793,4092006,11415077,60468277,1122637,72398035,-62267800,22082642,60359529,-16540633,92671879,-64462734,-55855043,-40899846,88007957,-57387813,-49552230,-96789394,18318594,-3246760,-44346548,-21370279,42493875,25185969,83216261,-70078020,-53687927,-76072023,-65863359,-61708176,-29175835,85675811,-80575807,-92211746,44755622,-23368379,23619674,-749263,-40707953,-68966953,72694581,-52328726,-78618474,40958224,-2921736,-55902268,-74278762,63342010,29076029,58781716,56045007,-67966567,-79405127,-45778231,-47167435,1586413,-58822903,-51277270,87348634,-86955956,-47418266,74884315,-36952674,-29067969,-98812826,-44893101,-22516153,-34522513,34091871,-79583480,47562301,6154068,87601405,-48859327,-2183204,17736781,31189878,-23814871,-35880166,39204002,93248899,-42067196,-49473145,-75235452,-61923200,64824322,-88505198,20903451,-80926102,56089387,-58094433,37743524,-71480010,-14975982,19473982,47085913,-90793462,-33520678,70775566,-76347995,-16091435,94700640,17183454,85735982,90399615,-86251609,-68167910,-95327478,90586275,-99524469,16999817,27815883,-88279865,53092631,75125438,44270568,-23129316,-846252,-59608044,90938699,80923976,3534451,6218186,41256179,-9165388,-11897463,92423776,-38991231,-6082654,92275443,74040861,77457712,-80549965,-42515693,69918944,-95198414,15677446,-52451179,-50111167,-23732840,39520751,-90474508,-27860023,65164540,26582346,-20183515,99018741,-2826130,-28461563,-24759460,-83828963,-1739800,71207113,26434787,52931083,-33111208,38314304,-29429107,-5567826,-5149750,9582750,85289753,75490866,-93202942,-85974081,7365682,-42953023,21825824,68329208,-87994788,3460985,18744871,-49724457,-12982362,-47800372,39958829,-95981751,-71017359,-18397211,27941418,-34699076,74174334,96928957,44328607,49293516,-39034828,5945763,-47046163,10986423,63478877,30677010,-21202664,-86235407,3164123,8956697,-9003909,-18929014,-73824245]
a = Solution()
print(a.fourSum(nums,-236727523))