题目:threeSumClosest
要求:
给一个包含 n 个整数的数组 S, 找到和与给定整数 target 最接近的三元组,返回这三个数的和。
注意事项
只需要返回三元组之和,无需返回三元组本身
样例:
例如 S = [-1, 2, 1, -4] and target = 1. 和最接近 1 的三元组是 -1 + 2 + 1 = 2.
算法要求:
O(n^2) 时间, O(1) 额外空间。
解题思路:
就是找离target最近的三个数的和即可。
改良一下三个数之和,然后用min来记录最近的和。
算法如下:
int threeSumClosest(vector<int> nums, int target) {
// write your code here
int min = 0x7f7f;
sort(nums.begin(), nums.end());
int size = nums.size();
for (int i = 0; i < size; i++) {
int j = i + 1, k = size - 1;
while (j < k) {
int sum = nums[i] + nums[j] + nums[k];
if (abs(min - target) > abs(sum - target)){
min = sum;
}
if (sum <= target) {
j++;
} else {
k--;
}
}
}
return min;
}