image

微信公众号:醉前端,关注可了解更多题目。

题 目

Q:给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d ,使得 a + b + c + d 的值与 target 相等?找出所有满足条件且不重复的四元组。注意:答案中不可以包含重复的四元组。

示例:

给定数组 nums = [1, 0, -1, 0, -2, 2],和 target = 0。

满足要求的四元组集合为:
[
[-1, 0, 0, 1],
[-2, -1, 1, 2],
[-2, 0, 0, 2]
]

答 案

const fourSum = (nums, target) => {
    let result = [];
    let len = nums.length;
    if (len < 4) {
        return result;
    }
    nums.sort((a,b) => a-b);
    for(i = 0; i < len-3; i++) {
        if (i > 0 && nums[i-1] === nums[i]) continue;
        for(j = i+1; j < len-2; j++) {
            if (j > i+1 && nums[j-1] === nums[j]) continue;
            let k = len - 1
            let c = j + 1;
            while(c < len-1 && c != k) {
                let sum = nums[i] + nums[j] + nums[c] + nums[k];
                if (c > j+1 && nums[c] === nums[c-1]) {
                    c++;
                    continue;
                }
                if (k < len-1 && nums[k] === nums[k+1]) {
                    k--;
                    continue;
                }
                if(sum === target) {
                    result.push([nums[i], nums[j], nums[c], nums[k]]);
                    c++;
                    k = nums.length - 1;
                }else if (sum < target) {
                    c++;
                }else{
                    k--;
                }
            }
        }
    }
    return result;
};

image


醉前端
174 声望83 粉丝

Time is a bird forever on the ring......