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

lintcode_59. 最接近的三数之和

时间:2017-12-11 16:11:49      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:strong   while   str   color   pos   整数   numbers   col   class   

给一个包含 n 个整数的数组 S, 找到和与给定整数 target 最接近的三元组,返回这三个数的和。

样例

例如 S = [-1, 2, 1, -4] and target = 1. 和最接近 1 的三元组是 -1 + 2 + 1 = 2.

class Solution:
    """
    @param: numbers: Give an array numbers of n integer
    @param: target: An integer
    @return: return the sum of the three integers, the sum closest target.
    """
    def threeSumClosest(self, numbers, target):
        # write your code here
        result = sum(numbers[:3]) -target
        
        for i in range(len(numbers)-2):
            for j in range(i+1,len(numbers)-1):
                for m in range(j+1,len(numbers)):
                    tmp = numbers[i]+numbers[j]+numbers[m]-target
                    if abs(result) > abs(tmp):
                        result = tmp
        return result+target

时间复杂度o(n^3)

九章算法参考:

class Solution:
    """
    @param numbers: Give an array numbers of n integer
    @param target : An integer
    @return : return the sum of the three integers, the sum closest target.
    """
    def threeSumClosest(self, numbers, target):
        numbers.sort()
        ans = None
        for i in range(len(numbers)):
            l, r = i + 1, len(numbers) - 1
            while (l < r):                    
                sum = numbers[l] + numbers[r] + numbers[i]
                if ans is None or abs(sum- target) < abs(ans - target):
                    ans = sum
                if sum <= target:
                    l = l + 1
                else:
                    r = r - 1
        return ans

有点类似背包问题,放缩的比较好,提高了效率

 

lintcode_59. 最接近的三数之和

标签:strong   while   str   color   pos   整数   numbers   col   class   

原文地址:http://www.cnblogs.com/zhangli-ncu/p/8023154.html

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