题目
给定一个包括 n 个整数的数组 nums 和 一个目标值 target。找出 nums 中的三个整数,使得它们的和与 target 最接近。返回这三个数的和。假定每组输入只存在唯一答案。
例如
给定数组 nums = [-1,2,1,-4], 和 target = 1.
与 target 最接近的三个数的和为 2. (-1 + 2 + 1 = 2).
来源:力扣(LeetCode)
思路
首先,定义一个变量 diff 用来记录差的绝对值;
然后,先对数组排序,开始遍历数组,思路跟三数之和类似;
其次,可以先确定一个数,用两个指针 left 和 right 来滑动寻找另外两个数,每确定两个数,求出此三数之和,然后求出与给定值的差的绝对值存入 newDiff 中;
最后,和 diff 比较并更新 diff 和结果 closest 。
C++代码
class Solution {
public:
int threeSumClosest(vector<int>& nums, int target)
{
int closest = nums[0] + nums[1] + nums[2];
int diff = abs(closest - target);
sort(nums.begin(), nums.end());
for (int i = 0; i < nums.size() - 2; ++i)
{
int left = i + 1, right = nums.size() - 1;
while (left < right)
{
int sum = nums[i] + nums[left] + nums[right];
int newDiff = abs(sum - target);
if (diff > newDiff)
{
diff = newDiff;
closest = sum;
}
if (sum < target)
++left;
else --right;
}
}
return closest;
}
};