58.4Sum
Last updated
Last updated
public ArrayList<ArrayList<Integer>> fourSum(int[] numbers, int target) {
ArrayList<ArrayList<Integer>> result=new ArrayList<>();
if(numbers==null || numbers.length<4){
return result;
}
Arrays.sort(numbers);
HashSet<ArrayList<Integer>> set=new HashSet<>();
for(int i=0;i<numbers.length-3;i++){
for(int j=i+1;j<numbers.length-2;j++){
int head=j+1;
int tail=numbers.length-1;
while(head<tail){
int sum=numbers[i]+numbers[j]+numbers[head]+numbers[tail];
if(sum>target){
tail--;
}
else if(sum<target){
head++;
}
else if(sum==target){
ArrayList<Integer> path=new ArrayList<Integer>();
path.add(numbers[i]);
path.add(numbers[j]);
path.add(numbers[head]);
path.add(numbers[tail]);
if(!set.contains(path)){
set.add(path);
result.add(path);
}
head++;
tail--;
}
}
}
}
return result;
}