码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode 3Sum Closest 最近似的3sum(2sum方法)

时间:2015-05-14 23:32:00      阅读:115      评论:0      收藏:0      [点我收藏+]

标签:

 

技术分享

题意:找到最接近target的3个元素之和,并返回该和。

思路:用2个指针,时间复杂度O(n^2)。

技术分享
 1 int threeSumClosest(vector<int>& nums, int target) {
 2     int sum=nums[0]+nums[1]+nums[2];
 3     sort(nums.begin(), nums.end());
 4     for(int i=0; i<nums.size()-2; i++)
 5     {
 6         int p=i+1, q=nums.size()-1;
 7         while( p!=q )
 8         {
 9             int tmp=target-(nums[i]+nums[p]+nums[q]);
10             if(abs(tmp)<abs(sum-target) )    sum=nums[i]+nums[p]+nums[q];
11             if(!tmp)    return target;
12             if(tmp>0)    p++;
13             else        q--;
14         }
15     }
16     return sum;
17 }
AC代码

 

LeetCode 3Sum Closest 最近似的3sum(2sum方法)

标签:

原文地址:http://www.cnblogs.com/xcw0754/p/4504719.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!