java数据结构与算法刷题-----LeetCode454. 四数相加 II

2024-01-30 01:28

本文主要是介绍java数据结构与算法刷题-----LeetCode454. 四数相加 II,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846

在这里插入图片描述

解题思路
  1. 共4个数组A,B,C,D,如果暴力枚举,就需要4个for循环,枚举每一种组合。则时间复杂度O( n 4 n^4 n4)
  2. 但是我们现在分为两组,A和B的每一种组合,和C和D的每一种组合. 时间复杂度就变成了2个O( n 2 n^2 n2)
  3. 关键:假设AB组合,有一个值是1.CD组合有一个值是-1.那么这个整体的组合,相加为0,显然是题目想要我们找到的。
  4. 问题时,我们如何将其对应到一起。我们发现这个完全符合题意的组合。如果CD组合的值取负,就和AB组合的值一样了。例如AB组合的数是-1000,CD组合的数是1000,那么CD取负变-1000. 此时两个组合的数就一样了,都是-1000.
  5. 所以我们可以建立 n 2 n^2 n2大小的hash表,存储所有AB组合的数,然后只需要判断CD组合取负后,是否和hash表中元素对应,如果对应,那么它们相加就一定归0.

而对于hash表来说,我们可以用做题的老套路,用数组充当hash表,做题效率更快,但是工作中可不能用这玩意。同时我也会给出用实实在在的Hash表来存储的方法,它的效率略逊于数组直接存取,但是工作中肯定得用这个。而对于做题来说,虽然hash表存储比用数组慢了2ms。但是就是这2ms,却超过了65%的人。而实际工作中,没必要为了这2ms来承受使用数组的风险。

代码:使用Map集合:时间复杂度O(n^ 2 ) 空间复杂度O(n^ 2),使用数组:时间复杂度O(n^2) 空间复杂度O(value) 其中value是数组中元素的取值范围

在这里插入图片描述

class Solution {/**方法一: 做题效率更高,时间复杂度和法二一样,都是O(n^2),但工作场景没什么意义使用数组充当hash表,工作中使用,会造成大量存储空间的浪费。它需要创建和数组取值范围一样大的用数组下标充当key,元素值为value的hash表*/public int[] getMaxMin(int[] nums) {//返回数组的最大和最小值int min = nums[0], max = nums[0];for (int num: nums) {if (num < min) min = num;else if (num > max) max = num;}return new int[] {max, min};}public int fourSumCount(int[] nums1, int[] nums2, int[] nums3, int[] nums4) {/****首先是使用数组作为hash表,需要用数组中最大值和最小值,得到取值范围,然后创建相应大小的hash表 *///获取4个数组的最大和最小值new int[]{max,min} 其中[0]存储max最大值,[1]存储最小值int[] max_min_1 = getMaxMin(nums1);int[] max_min_2 = getMaxMin(nums2);int[] max_min_3 = getMaxMin(nums3);int[] max_min_4 = getMaxMin(nums4);//两两为一组,一组为直接相加,一组为负数相加//分别获取两组最大和最小值,注意负数一组,加上负号后,值越大反而越小(比如-1 > -100)int max = Math.max(max_min_1[0] + max_min_2[0], -(max_min_3[1] + max_min_4[1]));int min = Math.min(max_min_1[1] + max_min_2[1], -(max_min_3[0] + max_min_4[0]));//用数组充当哈希表,取值范围为 这正负的两组 最小值到最大值。例如-1000 到 1000.int [] hash = new int [max - min + 1];int ans = 0;/** 下面的操作就和使用Map完全一样了*///分为两组,两个for循环,两个n^2. 比暴力解法4个for循环要好得多//正数这一组中,所有取值组合放入hash中for (int num1: nums1) {for (int num2: nums2) {++hash[num1 + num2 - min];//对应下标位置+1}}//负数这一组,如果取值组合和第一组的相同,那么证明,不取负的话,两组相加会归0for (int num3: nums3) {for (int num4: nums4) {ans += hash[-num3 - num4 - min];//则符合条件,将次数加入答案中}}return ans;}/**法二,因为使用了Map需要hash散列,还得维护hash表,存取效率比不上直接数组索引,但是实际工作中肯定使用Map,时间复杂度和法一相同O(n^2). 代码也完全一样。*/public int fourSumCount1(int[] A, int[] B, int[] C, int[] D) {//除了用了Map作为hash表外,其余操作完全一样Map<Integer,Integer> countAB = new HashMap<Integer,Integer>();//分两种,一组正数for(int u : A)for(int v : B) countAB.put(u + v,countAB.getOrDefault(u + v , 0) + 1);//放入hashint ans = 0;//一组负数,如果取负后,和第一组正数一致,就表示两组相加,会归0for(int u : C)for(int v : D)if(countAB.containsKey(-u - v))ans += countAB.get(-u - v);//那么就符合答案需要的return ans;}}

这篇关于java数据结构与算法刷题-----LeetCode454. 四数相加 II的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/658712

相关文章

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2