-
Notifications
You must be signed in to change notification settings - Fork 28
Expand file tree
/
Copy paththreeSumClosest.py
More file actions
30 lines (30 loc) · 1 KB
/
threeSumClosest.py
File metadata and controls
30 lines (30 loc) · 1 KB
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
def threeSumClosest(self, nums: List[int], target: int) -> int:
nums.sort()
l, ans, diff = len(nums), 1e18, 1e18
for i in range(l - 2):
if i > 0 and nums[i] == nums[i - 1]:
continue
left, right = i + 1, l - 1
while right - left > 15:
mid = (left + right) // 2
s = nums[left] + nums[right] + nums[i]
if s == target:
break
elif s > target:
right = mid
else:
left = mid
while right - left > 1:
s = nums[left] + nums[right] + nums[i]
if s == target:
break
elif s > target:
right -= 1
else:
left += 1
tt = nums[i] + nums[left] + nums[right]
t = abs(target - tt)
if diff > t:
ans = tt
diff = t
return ans