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. 最接近的三数之和(双指针)的主要内容,如果未能解决你的问题,请参考以下文章

16. 最接近的三数之和(双指针)

最接近的三数之和-排序+双指针

LeetCode 16. 最接近的三数之和

16. 最接近的三数之和

力扣16-最接近的三数之和&力扣18-四数之和

LeetCode 16. 最接近的三数之和