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

leetcode 18. 4Sum

时间:2019-12-15 00:47:24      阅读:67      评论:0      收藏:0      [点我收藏+]

标签:func   find   must   turn   cat   and   nts   foreach   elements   

Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = target? Find all unique quadruplets in the array which gives the sum of target.

Note: The solution set must not contain duplicate quadruplets.

For example, given array S = [1, 0, -1, 0, -2, 2], and target = 0.

A solution set is:
[
  [-1,  0, 0, 1],
  [-2, -1, 1, 2],
  [-2,  0, 0, 2]
]
var fourSum = function (nums, target) {
      nums.sort((a, b) => a - b)
      var len = nums.length
      return kSum(nums, len, 0, 4, target)

    };
    function kSum(nums, len, start, k, target) {
      if (k === 2) {
        return twoSum(nums, len, start, target)
      } else {
        var result = []
        for (var i = start; i < len; i++) {
          //不能是第一个
          if (i != start && nums[i] == nums[i - 1]) {
            continue
          }
          var ret = kSum(nums, len, i + 1, k - 1, target - nums[i])
          if (ret.length) {
            ret.forEach(function (el) {
              result.push([nums[i]].concat(el))
            })
          }
        }
        return result
      }
    }
    function twoSum(nums, len, start, target) {
      var left = start;
      var right = len - 1, ret = []
      while (left < right) {
        var sum = nums[left] + nums[right]
        if (sum === target) {
          ret.push([nums[left], nums[right]])
          while (nums[left] == nums[left + 1]) {
            left++
          }
          while (nums[right] == nums[right - 1]) {
            right--
          }
          left++
          right--
        } else if (sum > target) {
          right--
        } else {
          left++
        }
      }
      return ret
    }

leetcode 18. 4Sum

标签:func   find   must   turn   cat   and   nts   foreach   elements   

原文地址:https://www.cnblogs.com/rubylouvre/p/12041644.html

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