18. 4Sum

这道也是经典题目,要求跟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;
    }
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 18. 4Sum题目大意给定一个数组,一个target,要求找出所有和为target的四个数的集合,不能重复。 据...
    Reflection_阅读 1,469评论 0 0
  • 题目 Given an array S of n integers, are there elements a, ...
    Al73r阅读 1,241评论 0 0
  • 题目描述 Given an array S of n integers, are there elements a...
    云胡同学阅读 2,548评论 0 0
  • 类似这种k-sum的题,都简化为sorted array的2sum问题,即利用two pointers, 一个头,...
    尴尴尬尬先生阅读 2,586评论 0 0
  • 题目 Given an array S of n integers, are there elements a, ...
    persistent100阅读 1,352评论 0 0