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;
	}
}
相关推荐
郝学胜-神的一滴3 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
JH30733 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
颜酱4 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
m0_736919104 小时前
C++代码风格检查工具
开发语言·c++·算法
yugi9878384 小时前
基于MATLAB强化学习的单智能体与多智能体路径规划算法
算法·matlab
Coder_Boy_4 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
DuHz5 小时前
超宽带脉冲无线电(Ultra Wideband Impulse Radio, UWB)简介
论文阅读·算法·汽车·信息与通信·信号处理
invicinble5 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
发现一只大呆瓜5 小时前
前端性能优化:图片懒加载的三种手写方案
前端·javascript·面试
Polaris北极星少女5 小时前
TRSV优化2
算法