微信公众号:醉前端,关注可了解更多题目。
题 目
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;
};
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。