16. 3Sum Closest

Given an array S of n integers, find three integers in S such that the sum is closest to a given number, target. Return the sum of the three integers. You may assume that each input would have exactly one solution.

    For example, given array S = {-1 2 1 -4}, and target = 1.

    The sum that is closest to the target is 2. (-1 + 2 + 1 = 2).

 寻找三个数,使这三个数之和最接近target的值。

注意点包括取绝对值,遍历方法。一般遇到在一个列表里寻找三个数的情况,遍历方法一般为:

for(int i = 0; i < totalNum; i++){

  int j = i+1;
  int k = totalNum - 1;

      while(j<k){

  //接着看情况使  j++ 或  k--
    }
}

 

答案:

class Solution {
public:
    int threeSumClosest(vector<int> &num, int target) {        
    vector<int> v(num.begin(), num.end()); // 复制原容器内数据,排序时不破坏原数据
    int n = 0;
    int ans = 0;
    int sum;
    
    sort(v.begin(), v.end());            //对里面的数据元素排序
    
                                         
    while (v.size() <= 3) {              // 如果小于三个数,不用寻找,直接返回他们的和
        return accumulate(v.begin(), v.end(), 0);
    }
    
    n = v.size();
    ans = v[0] + v[1] + v[2];
    for (int i = 0; i < n-2; i++) {        //当一个元素固定式(i),剩余两个数据相互逼近来寻找最适元素,
        int j = i + 1;                     //一边从下一个元素开始
        int k = n - 1;                     //一边从最后一个元素开始。
        while (j < k) {                    //当j,k没有相遇
            sum = v[i] + v[j] + v[k];
            if (abs(target - ans) > abs(target - sum)) {
                ans = sum;
                if (ans == target) return ans;
            }
            (sum > target) ? k-- : j++;     
        //当sum大于target时,说明三个数之和太大了,应该让k向左走寻找更小的数据,而不是让j++寻找更大的数;反之。。。
        }
    }
    return ans;
}
};

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值