哈希表-四数之和

代码随想录-刷题笔记

18. 四数之和 - 力扣(LeetCode)

内容:

请一定要看上一篇文章!因为本题跟上一道题逻辑一模一样!

哈希表-三数之和-优快云博客

这道题跟上一道题的核心一模一样,三数之和可以进行一定程度的简化,变成O(n^2)级别的算法.

但是这道题 包括五数,六数,七数之后. N数之和 都是一个逻辑了。

只不过是进行一下套壳。

代码如下:

class Solution {
    public List<List<Integer>> fourSum(int[] nums, int target) {
        Arrays.sort(nums);
        List<List<Integer>> result = new ArrayList<>();
        for(int i = 0 ; i< nums.length ; i++) {
            if(nums[i] > target && nums[i]>=0) break;
            if(i>0 && nums[i] == nums[i-1]) continue;

            for(int j = i+1 ;j < nums.length ;j++) {
                if(nums[j]+nums[i] > target && nums[j]+nums[i] >=0) break;
                if(j>i+1&&nums[j]==nums[j-1]) continue;

                int left = j + 1;
                int right = nums.length -1;
                while(right > left) {
                    if(nums[i]+nums[j]+nums[left]+nums[right] > target) {
                        right--;
                    }else if(nums[i]+nums[j]+nums[left]+nums[right] < target) {
                        left++;
                    }else{
                        result.add(new ArrayList<>(Arrays.asList(nums[i],nums[j],nums[left],nums[right])));
                        while(right>left && nums[right] == nums[right-1]) right--;
                        while(right>left && nums[left] == nums[left+1]) left++;
                        left++;
                        right--;
                    }
                }

            }
        }
        return result;
    }
}

总结:

上一篇三数之和搞好了就可以了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值