首页 > 其他分享 >LeetCode_16. 最接近的三数之和

LeetCode_16. 最接近的三数之和

时间:2022-11-01 11:04:42浏览次数:46  
标签:end target nums int 三数 sum 16 start LeetCode


题目描述:

给定一个包括 n 个整数的数组 nums 和 一个目标值 target。找出 nums 中的三个整数,使得它们的和与 target 最接近。返回这三个数的和。假定每组输入只存在唯一答案。
例如,给定数组 nums = [-1,2,1,-4], 和 target = 1.
与 target 最接近的三个数的和为 2. (-1 + 2 + 1 = 2).

思路:此题目要求加和跟给定目标值最近的三个数的和,类似于​​三数之和​​,通过固定第一个数,遍历后面两个数(使用双指针的方法),每次都更新最小间距,更新最小和

class Solution {
public:
int threeSumClosest(vector<int>& nums, int target) {
sort(nums.begin(),nums.end());//对数组进行排序
int min=INT_MAX;
int ans=0;
for(int i=0;i<nums.size()-2;i++){
int sum=0;
int start=i+1;
int end=nums.size()-1;
while(start<end){
sum=nums[i]+nums[start]+nums[end];
if(abs(sum-target)<min){
min=abs(sum-target);
ans=sum;
}
if(sum>target)
end--;
else
start++;
}
}
return ans;
}
};

LeetCode_16. 最接近的三数之和_i++


标签:end,target,nums,int,三数,sum,16,start,LeetCode
From: https://blog.51cto.com/u_15855860/5812306

相关文章