2022-06-25 21
给定一个包括 n 个整数的数组 nums 和 一个目标值 target。找出 nums 中的三个整数,使得它们的和与 target 最接近。返回这三个数的和。假定每组输入只存在唯一答案。
示例1
输入: nums = [-1,2,1,-4], target = 1. 输出: 2 解释: 与 target 最接近的三个数的和为 2. (-1 + 2 + 1 = 2).
class Solution { public: int threeSumClosest(vector<int>& nums, int target) { int n = nums.size(), res = 10000000; sort(nums.begin(), nums.end() ); for (int i = 0; i < n - 2; ++i) { int l = i + 1, r = n - 1; while (l < r) { int sum = nums[i] + nums[l] + nums[r]; if (sum == target) return sum; if (abs(sum-target) < abs(res-target)) res = sum; if (sum > target) r--; else l++; } } return res; } };
class Solution: def threeSumClosest(self, nums: List[int], target: int) -> int: n, res = len(nums), 10000000 nums.sort() for i in range(n-2): l, r = i+1, n-1 while l < r: s = nums[i] + nums[l] + nums[r] if s == target: return s if abs(s-target) < abs(res-target): res = s if s > target: r -= 1 else: l += 1 return res
作者简介:godweiyang,知乎同名,华东师范大学计算机系硕士在读,方向自然语言处理与深度学习。喜欢与人分享技术与知识,期待与你的进一步交流~
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。