四数之和java版

题目描述

给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d ,使得 a + b + c + d 的值与 target 相等?找出所有满足条件且不重复的四元组。
注意:答案中不可以包含重复的四元组。
题目示例
题意:
这道题是求四个数的和相加等于目标值,然后要把重复的值去掉。
这个题的思路和力扣15-三数之和的思路类似,三数之和是固定一个数,其余进行双指针。四数之和是固定两个数,其余进行双指针。

解题思路:

参考官方题解

排序+双指针:先给数组nums进行升序排序,两个for循环确定前两个数,然后使用双指针确定后两个数,需要考虑以下几种情况进行剪枝:

在确定第一个数之后,如果nums[i] + nums[i+1] + nums[i+2] + nums[i+3] > target ,代表第一个数与之邻进的三个最小数之和都大于目标值了,则说明后面剩下的三个数无论取什么值,四数之和一定大于target,则需要退出第一轮循环;
在确定第一个数之后,如果nums[i] + nums[n-3] + nums[n-2] + nums[n-1] < target ,代表第一个数与数组中的三个最大数之和都小于目标值了,则说明后面剩下的三个数无论取什么值,四数之和一定小于target,则需要进入下一轮循环,枚举nums[i+1];
在确定前两个数之后,如果nums[i] + nums[j] + nums[j+1] + nums[j+2] > target ,说明剩下的两个数,无论取什么值,四个数之和一定会大于taret,因此退出第二层循环;
在确定前两个数之后,如果nums[i] + nums[j] + nums[n-2] + nums[n-1] < target ,说明剩下的两个数,无论取什么值,四个数之和一定会小于taret,因此进入下一轮,枚举nums[j+1];
使用双指针:左右指针分别指向下标 j+1和下标 n-1。每次计算四个数的和sum,并进行如下操作:

如果和 sum == target,则将枚举到的四个数加到答案中,然后将左指针右移直到遇到不同的数,将右指针左移直到遇到不同的数;

如果和sum < target,则将左指针右移一位;

如果和sum > target,则将右指针左移一位。

public List<List<Integer>> fourSum(int[] nums, int target) {List<List<Integer>> res = new ArrayList<List<Integer>>();int n = nums.length;//如果数组的长度小于4if(n < 4) return res;//对数组进行排序Arrays.sort(nums);//第一个数,只能遍历到倒数第4位for(int i = 0; i < n-3; i++){//:先去掉重复值if(i > 0 && nums[i] == nums[i-1]) continue;//如果邻近的四个数大于target,则退出if((long)nums[i] + nums[i+1] + nums[i+2] + nums[i+3] > target) break;//如果与最大的三个数相加小于target,则说明nums[i]小了,需要进入新一轮循环if((long)nums[i] + nums[n-3] + nums[n-2] + nums[n-1] < target) continue;//确定第二个数for(int j = i+1; j < n-2; j++){
//去重if(j > i + 1 && nums[j] == nums[j - 1]) continue;if((long)nums[i] + nums[j] + nums[j+1] + nums[j+2] > target) break;if((long)nums[i] + nums[j] + nums[n-2] + nums[n-1] < target) continue;//确定了两个数之后,后两个数使用双指针int L = j + 1;int R = n - 1;while(L < R){int sum = nums[i] + nums[j] + nums[L] + nums[R];if(sum == target){res.add(Arrays.asList(nums[i], nums[j], nums[L], nums[R]));//跳过重复数while(L < R && nums[L] == nums[L + 1]) L++;while(L < R && nums[R] == nums[R - 1]) R--;L++;R--;}else if(sum < target){L++;}else{R--;}}}}return res;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/213897.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电巢广西农业职业技术大学“硬件岗位岗前项目实训”结班啦!

为深化校企合作&#xff0c;产教融合助力新工科建设&#xff0c;提升学生工程实践能力&#xff0c;电巢工程能力实训班按照不同岗位类别&#xff0c;匹配对应的企业岗位任职能力要求对学生开展分级培养&#xff0c;以产业需求为导向&#xff0c;培养创新型、应用型人才。 11月…

Android Studio记录一个错误:Execution failed for task ‘:app:lintVitalRelease‘.

Android出现Execution failed for task :app:lintVitalRelease.> Lint found fatal errors while assembling a release target. Execution failed for task :app:lintVitalRelease解决方法 Execution failed for task ‘:app:lintVitalRelease’ build project 可以正常执…

如何开发洗鞋店用的小程序

随着人们生活水平的提高&#xff0c;洗护行业是越来越细分化了&#xff0c;从最开始的干洗店包含洗护行业的所有服务到现在有专门为洗鞋开的店&#xff0c;如果开发一款洗鞋店用的小程序&#xff0c;可以实现用户在家下单直接有人上门取鞋的话&#xff0c;应该如何去开发呢&…

工业以太网交换机未来发展中的几个趋势

随着工业自动化不断发展和智能制造的推进&#xff0c;工业以太网交换机在未来的应用中将面临更多的发展机遇和挑战。在工业以太网交换机的未来发展中&#xff0c;有几个方面将成为趋势。 网络虚拟化 随着工业自动化系统规模的不断扩展&#xff0c;网络虚拟化将成为未来的发展方…

nf_conntrack内核模块常见问题

nf_conntrack内核模块常见问题 问题描述排查步骤前置条件&#xff1a;启用nf_conntrack内核模块检查nf_conntrack配置 解决办法1:半数减少nf_conntrack buckets的值解决办法2:加倍调大m.min_free_kbytes值解决办法3:Linux社区权威答复-忽略告警 问题描述 内核报错 falling bac…

【LeetCode:1410. HTML 实体解析器 | 模拟+哈希表+字符串+库函数】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…

vue3.0使用leaflet

1、获取天地图密钥; 访问:https://www.tianditu.gov.cn/ 注册并登录,访问开发资源 =》地图API =》 地图服务=》申请key 应用管理=》创建新应用=》获取到对应天地图key 2、引入leaflet组件 参考资料:https://leafletjs.com/reference.html#path npm install leaflet …

制造业6S管理方法的卓越价值

在现代制造业中&#xff0c;高效管理和生产流程的优化对企业的成功至关重要&#xff0c;其中&#xff0c;6S管理方法作为精益生产的关键组成部分&#xff0c;为企业提供了卓越的管理模式。下面将深入探讨6S管理方法的价值&#xff0c;特别聚焦于周转箱和工具柜在精益生产中的优…

【Java 进阶篇】Redis持久化之RDB:数据的安全守护者

Redis&#xff0c;作为一款高性能的键值存储系统&#xff0c;支持多种持久化方式&#xff0c;其中RDB&#xff08;Redis DataBase&#xff09;是其最常用的一种。RDB可以将当前时刻的数据快照保存到磁盘&#xff0c;以便在Redis重启时快速恢复数据。本文将深入探讨RDB的原理、配…

springboot+vue基本微信小程序的旅游社系统

项目介绍 现今市面上有关于旅游信息管理的微信小程序还是比较少的&#xff0c;所以本课题想对如今这么多的旅游景区做一个收集和分类。这样可以给身边喜欢旅游的朋友更好地推荐分享适合去旅行的地方。 前端采用HTML架构&#xff0c;遵循HTMLss JavaScript的开发方式&#xff0…

机器学习探索计划——数据集划分

文章目录 导包手写数据划分函数使用sklearn内置的划分数据函数stratifyy理解举例 导包 import numpy as np from matplotlib import pyplot as plt from sklearn.datasets import make_blobs手写数据划分函数 x, y make_blobs(n_samples 300,n_features 2,centers 3,clus…

『Linux升级路』基础开发工具——gcc/g++篇

&#x1f525;博客主页&#xff1a;小王又困了 &#x1f4da;系列专栏&#xff1a;Linux &#x1f31f;人之为学&#xff0c;不日近则日退 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 目录 一、快速认识gcc/g 二、预处理 &#x1f4d2;1.1头文件展开 &#x1f4d2;1…