18. 四数之和
题目:
给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d ,使得 a + b + c + d 的值与 target 相等?找出所有满足条件且不重复的四元组。
答案中不可以包含重复的四元组。
示例:
给定数组 nums = [1, 0, -1, 0, -2, 2],和 target = 0。
满足要求的四元组集合为:
[
[-1, 0, 0, 1],
[-2, -1, 1, 2],
[-2, 0, 0, 2]
]
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/4sum
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
代码:
class Solution {
public List<List
int len=nums.length;
Arrays.sort(nums);
int sum=0;
var set=new HashSet<ArrayList
for(int i=0;i<len-3;i++){
for(int j=i+1;j<len-2;j++){
for(int k=j+1,l=len-1;k<l;){
sum=nums[i]+nums[j]+nums[k]+nums[l];
if(sum==target){
var array=new ArrayList();
array.add(nums[i]);
array.add(nums[j]);
array.add(nums[k]);
array.add(nums[l]);
if(!set.contains(array)){
set.add(array);
}
}
if(sum<target){
k++;
}
else{
l--;
}
}
}
}
return new ArrayList<List<Integer>>(set);
}
}
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
· 提示词工程——AI应用必不可少的技术