/**
* @param {number[]} nums
* @param {number} target
* @return {number}
*/
const threeSumClosest = (nums, target) => {
// 升序排序
nums.sort((a, b) => a - b);
// 初始化一个最小值
let min = Infinity;
const len = nums.length;
for (let i = 0; i < len; i++) {
// 定义左右指针
let [left, right] = [i + 1, len - 1];
while (left < right) {
// 当前三数之和
const sum = nums[i] + nums[left] + nums[right];
// 如果当前和更接近,更新最小值
if (Math.abs(sum - target) < Math.abs(min - target)) {
min = sum;
}
// 根据sum和target的关系,移动指针
if (sum < target) {
left++;
} else if (sum > target) {
right--;
} else {
// sum和target相等,直接返回sum,肯定是最小的了
return sum;
}
}
}
// 遍历结束,返回最接近的和
return min;
};
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
31
32
33
34
35
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
31
32
33
34
35