18. 4Sum

3Sum基础上,固定第一个数对剩下的数进行3Sum
计算,复杂度为O(n^3)

class Solution {
    public List<List<Integer>> fourSum(int[] nums, int target) {
        List<List<Integer>> zz = new ArrayList<>();
        Arrays.sort(nums);
        int len = nums.length;
        if(len<4)
            return zz;
        for(int i=0;i<len-3;i++){
            while(i!=0&&i<len-3&&nums[i]==nums[i-1])i++;
            for(int j=i+1;j<len-2;j++){
                while(j!=i+1&&j<len-2&&nums[j]==nums[j-1])j++;
                int p = j+1,q = len-1;
                while(p<q){
                    int dis = nums[i]+nums[j]+nums[p]+nums[q]-target;
                    if(dis<0){
                        p++;
                    }else if(dis==0){
                        List<Integer> tmp = new ArrayList<>();
                        tmp.add(nums[i]);
                        tmp.add(nums[j]);
                        tmp.add(nums[p]);
                        tmp.add(nums[q]);
                        zz.add(tmp);
                        p++;
                        q--;
                        while(p<q&&nums[p]==nums[p-1])p++;
                        while(p<q&&nums[q]==nums[q+1])q--;
                    }else{
                        q--;
                    }
                }
            }
        }
        return zz;
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,788评论 0 33
  • 题目描述:给定一个有n个整数的数组S和目标值target,找到其中所有由四个数a、b、c、d组成,使得a + b ...
    Nautilus1阅读 1,952评论 0 1
  • 下文出自我的QQ心情日志 隐 2015-3-28 23:29 ………… 他们说这就是人生,总得试着体会。 还记得初...
    故姒阅读 241评论 1 0
  • 我历来觉得 漂泊 会是件好事 这种情怀也向往已久 可此刻 毫无思绪的此刻 我没想到 这种情怀却略显可怕 像是一堆快...
    粗觉得阅读 269评论 0 0
  • 开锁是我,桌面是他,贼幸福
    鹤小姐阅读 168评论 0 0