16. 最接近的三数之和(双指针)
Posted Ston.V
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了16. 最接近的三数之和(双指针)相关的知识,希望对你有一定的参考价值。
1.Description
给你一个长度为 n 的整数数组 nums 和 一个目标值 target。请你从 nums 中选出三个整数,使它们的和与 target 最接近。
返回这三个数的和。
假定每组输入只存在恰好一个解。
2.Example
示例 1:
输入:nums = [-1,2,1,-4], target = 1
输出:2
解释:与 target 最接近的和是 2 (-1 + 2 + 1 = 2) 。
示例 2:输入:nums = [0,0,0], target = 1
输出:0
3.Code
双指针的思想,做法和三数之和几乎一样,这里不判重了,反正不影响最终答案
class Solution
public:
int threeSumClosest(vector<int>& nums, int target)
int n = nums.size();
sort(nums.begin(),nums.end());
int gap = target-nums[0]-nums[1]-nums[2];
int res = target-gap;
for(int i=0;i<n;i++)
int j=i+1,k=n-1;
while(j<k)
int tmp =nums[i] + nums[j] + nums[k];
if(tmp < target)j++;
else if(tmp >= target)k--;
if(abs(target - tmp)<abs(gap))
res = tmp;
gap = target - tmp;
return res;
;
以上是关于16. 最接近的三数之和(双指针)的主要内容,如果未能解决你的问题,请参考以下文章