leetcode18-4Sum

题目

给你一个由 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

你可以按 任意顺序 返回答案 。

示例 1:

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

输出:[[-2,-1,1,2],[-2,0,0,2],[-1,0,0,1]]

分析

这道题目很前面的三数之和的解法完全一样,四个数字我们就固定俩个数字,然后在剩下的数字里面寻找2个复合要求的数字,注意第一个for的剪枝

java 复制代码
import java.util.List;
import java.util.ArrayList;
import java.util.Set;
import java.util.HashSet;
import java.util.Arrays;

public class fourSum {
	public static void main(String[] args) {
		int[] arr = {1,0,-1,0,-2,2};
		List<List<Integer>> res = getFour(arr,0);
		for(List<Integer> lis : res) {
			for(Integer data : lis) {
				System.out.print(data + " ");
			}
			System.out.println();
		}
	}
	public static List<List<Integer>> getFour(int[] arr,int target) {
		int len = arr.length;
		Arrays.sort(arr);
		Set<List<Integer>> set = new HashSet();
		for(int i = 0;i<len-3;i++) {
			if(i > 0 && arr[i] == arr[i-1]) {
				continue;
			}
			for(int j = i+1;j<len-2;j++) {
				int m = j+1;
				int n = len - 1;
				while(m<n) {
					int data = arr[i]+arr[j]+arr[m]+arr[n];
					if(data == target) {
						List<Integer> lis = new ArrayList();
						lis.add(arr[i]);
						lis.add(arr[j]);
						lis.add(arr[m]);
						lis.add(arr[n]);
						set.add(lis);
						m++;
						n--;
					} else if(data < target) {
						m++;
					} else {
						n--;
					}
				}
			}
		}
		List<List<Integer>> res = new ArrayList();
		res.addAll(set);
		return res;
	}
}
相关推荐
秋说41 分钟前
【PTA数据结构 | C语言版】一元多项式求导
c语言·数据结构·算法
Maybyy1 小时前
力扣61.旋转链表
算法·leetcode·链表
一只叫煤球的猫1 小时前
【🤣离谱整活】我写了一篇程序员掉进 Java 异世界的短篇小说
java·后端·程序员
斐波娜娜1 小时前
Maven详解
java·开发语言·maven
Bug退退退1231 小时前
RabbitMQ 高级特性之事务
java·分布式·spring·rabbitmq
程序员秘密基地1 小时前
基于html,css,vue,vscode,idea,,java,springboot,mysql数据库,在线旅游,景点管理系统
java·spring boot·mysql·spring·web3
皮皮林5512 小时前
自从用了CheckStyle插件,代码写的越来越规范了....
java
小码氓2 小时前
Java填充Word模板
java·开发语言·spring·word
会飞的天明2 小时前
Java 导出word 实现饼状图导出--可编辑数据
java·word
Muxiyale2 小时前
使用spring发送邮件,部署ECS服务器
java·服务器·spring