九章算法NineChapter 2021-01-20 28浏览量
描述
给一个包含 n 个整数的数组 S, 找到和与给定整数 target 最接近的三元组,返回这三个数的和。
只需要返回三元组之和,无需返回三元组本身
在线评测地址:领扣题库官网
样例1
输入:[2,7,11,15],3
输出:20
解释:
2+7+11=20
样例2
输入:[-1,2,1,-4],1
输出:2
解释:
-1+2+1=2
解法思路
class Solution:
"""
@param numbers: Give an array numbers of n integer
@param target: An integer
@return: return the sum of the three integers, the sum closest target.
"""
def threeSumClosest(self, numbers, target):
nearest = float('inf')
# step1: 首先对数组进行排序
numbers = sorted(numbers)
# step2: 遍历
for i in range(len(numbers) - 2):
# 剪枝1
if (i > 0 and numbers[i] == numbers[i - 1]):
continue
# 定义双指针
left = i + 1
right = len(numbers) - 1
# 双指针相向而行
while (left < right):
# 此时的三数之和
curr = numbers[left] + numbers[right] + numbers[i]
# 和恰好为target
if curr == target:
return target
# 更新 nearest
if abs(curr - target) < abs(nearest - target):
nearest = curr
# 移动双指针
if curr > target:
right -= 1
# 剪枝2
while (right >= 0 and numbers[right] == numbers[right + 1]):
right -= 1
else:
left += 1
# 剪枝3
while (left < len(numbers) and numbers[left] == numbers[left - 1]):
left += 1
return nearest
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
开发者社区在线编程频道官方技术圈。包含算法资源更新,周赛动态,每日一题互动。