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

Leetcode 15 3Sum

时间:2015-06-14 19:58:09      阅读:129      评论:0      收藏:0      [点我收藏+]

标签:

Given an array S of n integers, are there elements abc in S such that a + b + c = 0? Find all unique triplets in the array which gives the sum of zero.

Note:

  • Elements in a triplet (a,b,c) must be in non-descending order. (ie, a ≤ b ≤ c)
  • The solution set must not contain duplicate triplets.

 

    For example, given array S = {-1 0 1 2 -1 -4},

    A solution set is:
    (-1, 0, 1)
    (-1, -1, 2)

排序后,遍历途中使用初始值分别为当前遍历点后一点和数组最后一点的指针,如果三值之和大于0,则后指针向左移动使后三值之和减小;反之前指针向右移动。

def three_sum(nums)
  ans = []
  return ans if nums.length < 3
  a = nums.sort
  (a.length-2).times do |i|
    j, k = i+1, a.length-1
    while j < k
      if a[i] + a[j] + a[k] == 0
        ans << [a[i],a[j],a[k]]
        j += 1
        k -= 1
      elsif a[i] + a[j] + a[k] > 0
        k -= 1
      elsif a[i] + a[j] + a[k] < 0
        j += 1
      end
    end
  end
  ans.uniq
end

 

Leetcode 15 3Sum

标签:

原文地址:http://www.cnblogs.com/lilixu/p/4575528.html

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