这道也是经典题目,要求跟two sum 不太一样,要求去重。
所以这道题要用到以下基本功
1。去重
2。 双指针。
3。 可以剪枝优化
下面帖下我的代码, 剪枝前50%左右排名,剪枝后99%。
public List<List<Integer>> fourSum(int[] nums, int target) {
Arrays.sort(nums);
List<List<Integer>> ans = new ArrayList<>();
for (int i = 0; i + 3 < nums.length; i++) {
//去重
if (i != 0 && nums[i] == nums[i - 1]) continue;
//剪枝
if (nums[i] * 4 > target) break;
if (nums[i] + 3 * nums[nums.length - 1] < target) continue;
for (int j = i + 1; j + 2 < nums.length; j++) {
if (j != i + 1 && nums[j - 1] == nums[j]) continue;
//剪枝
if (nums[i] + nums[j] * 3 > target) break;
if (nums[i] + nums[j] + 2 * nums[nums.length - 1] < target) continue;
int l = j + 1, r = nums.length - 1;
int localTarget = target - nums[i] - nums[j];
while (l < r) {
//剪枝
if (nums[i] + nums[j] + nums[l] * 2 > target) break;
if (nums[i] + nums[j] + nums[r] * 2 < target) break;
if (nums[l] + nums[r] == localTarget) {
ans.add(Arrays.asList(nums[i], nums[j], nums[l],nums[r]));
//去重
while (l + 1 < nums.length && nums[l] == nums[l + 1]) {
l++;
}
l++;
while (r - 1 > 0 && nums[r] == nums[r - 1]) {
r--;
}
r--;
} else if (nums[l] + nums[r] < localTarget) {
l++;
} else {
r--;
}
}
}
}
return ans;
}