18. 4Sum

这道也是经典题目,要求跟two sum 不太一样,要求去重。
所以这道题要用到以下基本功
1。去重
2。 双指针。
3。 可以剪枝优化
下面帖下我的代码, 剪枝前50%左右排名,剪枝后99%。

    public List> fourSum(int[] nums, int target) {
        Arrays.sort(nums);
        List> 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;
    }

你可能感兴趣的:(18. 4Sum)