首页 > 其他分享 >刷刷刷Day7| 18. 四数之和

刷刷刷Day7| 18. 四数之和

时间:2023-01-05 21:00:36浏览次数:59  
标签:四数 target nums int Day7 right 18 指针 left

18. 四数之和

LeetCode题目要求

给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复):
0 <= a, b, c, d < n
a、b、c 和 d 互不相同
nums[a] + nums[b] + nums[c] + nums[d] == target
你可以按 任意顺序 返回答案 。

示例

输入:nums = [1,0,-1,0,-2,2], target = 0
输出:[[-2,-1,1,2],[-2,0,0,2],[-1,0,0,1]]

输入:nums = [2,2,2,2,2], target = 8
输出:[[2,2,2,2]]
解题思路

大致过程如下图:

图

思想类似三数之和的处理,关键在于指针的移动以及可能出现重复的处理。详细内容可以参看代码的说明

上代码

class Solution {
    public List<List<Integer>> fourSum(int[] nums, int target) {
        List<List<Integer>> res = new ArrayList<>();
        // 先排序,便于后续的指针移动及和相加、去重处理
        Arrays.sort(nums);
        
        int len = nums.length;

        // 第一层循环,指针为 i
        for (int i = 0; i < len; i++) {
            // 如果 i 指针的值大于 0 并且 大于 target,由于数组排序,不能出现和为 target, 所以这里直接就返回结果
            if (nums[i] > 0 && nums[i] > target) {
                return res;
            }

            // 去重处理,当前指针的值与前一次的相等,那么就不再处理,直接进入下一次循环
            if (i > 0 && nums[i] == nums[i-1]) {
                continue;
            }

            // 第二层循环,指针为 j
            for (int j = i + 1; j < len; j++) {
                // 去重处理,当前指针的值与前一次的相等,那么就不再处理,直接进入下一次循环
                if (j > i + 1 && nums[j] == nums[j-1]) {
                    continue;
                }

                // 移动的 left 指针,使用 j + 1
                int left = j + 1;
                // 移动的 right 指针,使用 len - 1
                int right = len - 1;

                // 迭代移动
                while (left < right) {
                    // i、j、left、right 四个指针的值相加
                    int c = nums[i] + nums[j] + nums[left] + nums[right];
                    // 如果和 > 目标值,那么移动 right,向左收缩操作,也就是让 right 指针的值小
                    if (c > target) {
                        right--;
                    } else if (c < target) {
                        // 这里是和 < 目标值,那么移动 left,向右收缩操作,也就是让 left 指针的值变大
                        left++;
                    } else {
                        // 如果相等,直接放入结果集
                        res.add(Arrays.asList(nums[i], nums[j], nums[left], nums[right]));
                        // 去重操作,因为即使找到了结果,对于 left、right 对应的值有可能和前后是相等,要想结果不重复,需要在这里进行处理
                        // 首先还是在 left < right 的前提条件下,然后判断是否相等,相等就移动指针
                        while (left < right && nums[left] == nums[left+1]) left++;
                        while (left < right && nums[right] == nums[right-1]) right--;

                        // 这里在去重后再移动 left、 right 指针,供下一次循环使用
                        left++;
                        right--;
                    }
                }
            }
        }

        return res;
    }
}
重难点

去重,在第一层循环,第二层循环,及找到结果集时都需要做去重处理,否则结果可能就有问题了

附:学习资料链接

标签:四数,target,nums,int,Day7,right,18,指针,left
From: https://www.cnblogs.com/blacksonny/p/17028848.html

相关文章

  • 优维低代码:I18n 国际化
    优维低代码技术专栏,是一个全新的、技术为主的专栏,由优维技术委员会成员执笔,基于优维7年低代码技术研发及运维成果,主要介绍低代码相关的技术原理及架构逻辑,目的是给广大运维......
  • NFS协议分析 - rfc1813
    IntroductionNFS协议实现基于RPC(RemoteProcedureCall)和XDR(eXternalDataRepresentation)XDR:astandardwayofrepresentingasetofdatatypesonanetwork该文档......
  • ​ 美国亚马逊带绳窗帘产品ANSI/WCMA A100.1-2018新标准测试
     美国消费品安全委员会(CPSC)于2022年11月2日通过了一项新的联邦安全标准。该标准适用于定制窗帘的操作绳,目的是降低带绳窗帘导致儿童窒息死亡和严重危及生命的伤害的风险。......
  • 代码随想录算法训练营第七天 |454.四数相加II 383. 赎金信 15. 三数之和 18. 四数之和
    454.四数相加II文章:代码随想录(programmercarl.com)视频:学透哈希表,map使用有技巧!LeetCode:454.四数相加II_哔哩哔哩_bilibili思路:首先定义一个unordered_map,key放a......
  • 刷刷刷Day7| 15. 三数之和
    15.三数之和LeetCode题目要求给你一个整数数组nums,判断是否存在三元组[nums[i],nums[j],nums[k]]满足i!=j、i!=k且j!=k,同时还满足nums[i]+nums[j]+......
  • 1802. 有界数组中指定下标处的最大值
    1802.有界数组中指定下标处的最大值classSolution{publicintmaxValue(intn,intindex,intmaxSum){intl=1,r=(int)1e9;while(l......
  • mac版达芬奇软件DaVinci Resolve Studio 18 v18.1.2B6密钥版
    mac版达芬奇软件哪里可以下载呢?小编为大家带来了mac版达芬奇软件DaVinciResolveStudio18v18.1.2B6密钥版,DaVinciResolve18破解版新增了几十项新功能和流程改进,使得剪......
  • 2018年笔记,突然看到2018年以前的一些笔记
    看到以前一些笔记,以前怕别人看到的笔记,居然写太认真就删了,苦了此心血,现在越工作了笔记反尔随心,现在自己的笔记除了自己能看懂,别人看到肯会乱自己要反省自己,  纯属回忆......
  • FreeSWITCH学习笔记18 - Event Socket
    目录:   18.1、架构18.1.1、外连模式 18.1.2、内连模式 18.2、EventSocket协议18.2.1、外连                       ......
  • LOJ #2842. 「JOISC 2018 Day 4」野猪
    题面传送门考试的时候只想到处理\(O(1)\)的边没想到维护\(O(1)\)的路径。首先如果没有可以退一步的限制显然就是相邻两点的最短路之和。退一步的限制想到点边互换。与处......