16. 3Sum Closest

原创 2016年08月29日 22:42:39

枚举+二分搜索

class Solution {
public:
    int threeSumClosest(vector<int>& nums, int target) {
        int n=nums.size();
        int i,j,k;
        int ans=nums[0]+nums[1]+nums[2];
        sort(nums.begin(),nums.end());
        
        for(i=0;i<=n-3;i++)
        {
            if(i>0&&nums[i]==nums[i-1])
                continue;
            for(j=i+1,k=n-1;j<k;)
            {
                if(j>i+1&&nums[j]==nums[j-1])
                {
                    j++;
                    continue;
                }
                if(k<n-1&&nums[k]==nums[k+1])
                {
                    k--;
                    continue;
                }
                int d=nums[i]+nums[j]+nums[k];
                if(d==target)
                    return d;
                else if(d>target)
                    k--;
                else
                    j++;
                if(abs(d-target)<abs(ans-target))
                    ans=d;
            }
        }
        return ans;
    }
};


LeetCode 16 3Sum Closest(C,C++,Java,Python)

Problem: Given an array S of n integers, find three integers in S such that the sum is closest ...
  • runningtortoises
  • runningtortoises
  • 2015年05月09日 22:26
  • 1729

leetcode-java-16. 3Sum Closest

思路: 先升序排序,然后用第一重for循环确定第一个数字。 然后在第二重循环里,第二、第三个数字分别从两端往中间扫。 如果三个数的total等于target,返回target。 如果三个数的t...
  • github_34514750
  • github_34514750
  • 2016年06月07日 21:47
  • 486

【LeetCode】3Sum Closest 解题报告

【题目】 Given an array S of n integers, find three integers in S such that the sum is closest to a gi...
  • ljiabin
  • ljiabin
  • 2014年10月30日 16:57
  • 7784

Leetcode #16 3Sum Closest 找3数之和最接近 解题小节

1 题目理解昨晚上光顾着吃深夜泡面,忘了更新了。。所以这一更就算是补上昨天的,今天的另算。这道题和 Leetcode #15 3Sum 三数之和 解题小节 很像,区别是#15是要三数之和等于目标值,这...
  • MebiuW
  • MebiuW
  • 2016年03月19日 10:13
  • 453

LeetCode16——3Sum Closest

Given an array S of n integers, find three integers in S such that the sum is closest to a given num...
  • booirror
  • booirror
  • 2015年03月12日 00:00
  • 1308

15. 3Sum,16. 3Sum Closest,18. 4Sum(最后一个方法重要)重要

第一题、15. 3Sum Given an array S of n integers, are there elements a, b, c in S such that a + b + c = ...
  • shanshanhi
  • shanshanhi
  • 2017年02月28日 18:38
  • 227

leetcode-16 3Sum Closest

问题描述: Given an array S of n integers, find three integers in S such that the sum is closest to...
  • woliuyunyicai
  • woliuyunyicai
  • 2015年04月12日 10:38
  • 728

LeetCode(16) 3Sum Closest

class Solution { public: int threeSumClosest(vector& nums, int target) { sort(nums.begin(...
  • guanzhongshan
  • guanzhongshan
  • 2015年07月16日 16:41
  • 387

16. 3Sum Closest Leetcode Python

Given an array S of n integers, find three integers in S such that the sum is closest to a given num...
  • hyperbolechi
  • hyperbolechi
  • 2015年01月17日 10:10
  • 695

leetcode第16题——**3Sum Closest

题目 Given an array S of n integers, find three integers in S such that the sum is closest to a give...
  • buptlrw
  • buptlrw
  • 2016年01月22日 14:58
  • 358
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:16. 3Sum Closest
举报原因:
原因补充:

(最多只允许输入30个字)