DAY 39 leetcode 18--哈希表.四数之和

题号18

给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复):

和上一题类似的思路,只不过多加了一层循环

java 复制代码
class Solution {
    public List<List<Integer>> fourSum(int[] nums, int target) {
        List<List<Integer>> ans=new ArrayList<>();//创建列表的列表
        Arrays.sort(nums);//先排序
        int size=nums.length;
        int a=0;
        int d=size-1;

        while(a<size-3){
            if(a>0&&nums[a]==nums[a-1])
            {
                a++;//注意要先自增
                continue;//有重复,跳过
            }
            int b=a+1;
            while(b<size-2){
                if(b>a+1&&nums[b]==nums[b-1])
                {
                b++;
                continue;
                }
                int c=b+1;
                 d=size-1;
                while(c<d){
                    long sum=(long) nums[a]+nums[b]+nums[c]+nums[d];//注意long类型
                    if(sum<target)
                    c++;
                    else if(sum>target)
                    d--;
                    else
                    {
                        //去重
                        while(c<d&&nums[c]==nums[c+1])
                        c++;
                        while(c<d&&nums[d]==nums[d-1])
                        d--;
                        //插入操作
                        ans.add(Arrays.asList(nums[a],nums[b],nums[c],nums[d]));
                        c++;
                        d--;
                    }
                }
               
                b++;

            }
            a++;
        }
        return ans;
    }
}
相关推荐
你知道网上冲浪吗26 分钟前
【原创理论】Stochastic Coupled Dyadic System (SCDS):一个用于两性关系动力学建模的随机耦合系统框架
python·算法·数学建模·数值分析
地平线开发者2 小时前
征程 6 | PTQ 精度调优辅助代码,总有你用得上的
算法·自动驾驶
Tisfy2 小时前
LeetCode 837.新 21 点:动态规划+滑动窗口
数学·算法·leetcode·动态规划·dp·滑动窗口·概率
CoovallyAIHub3 小时前
为高空安全上双保险!无人机AI护航,YOLOv5秒判安全带,守护施工生命线
深度学习·算法·计算机视觉
huangzixuan10073 小时前
08.18总结
算法·深度优先·图论
逆向菜鸟3 小时前
【摧毁比特币】椭圆曲线象限细分求k-陈墨仙
python·算法
DolphinDB3 小时前
DolphinDB 回测插件快速上手
算法
利刃大大4 小时前
【动态规划:路径问题】最小路径和 && 地下城游戏
算法·动态规划·cpp·路径问题
武大打工仔4 小时前
用 Java 复现哲学家就餐问题
算法
要做朋鱼燕4 小时前
【数据结构】用堆解决TOPK问题
数据结构·算法