-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy path18. 4Sum.cpp
64 lines (59 loc) · 1.6 KB
/
18. 4Sum.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#include<stdio.h>
#include<stdlib.h>
int cmpfunc(const void * a, const void * b)
{
return ( *(int*)a - *(int*)b );
}
int** fourSum(int* nums, int numsSize, int target, int* returnSize) {
int m,n,i,j;
int **p;
int size;
int sum;
p = (int **)malloc(sizeof(int *)*100);
qsort(nums,numsSize,sizeof(int),cmpfunc);
size = 0;
*returnSize = 0;
for(m=0;m<numsSize - 3;m++ ){
if(nums[m]+nums[m+1]+nums[m+2]+nums[m+3] > target) break; //×îС±Ètarget´ó
if(nums[m]+nums[numsSize-1]+nums[numsSize-2]+nums[numsSize-3] < target) continue;
for(n=m+1;n<numsSize-2;n++ ){ //3Sum
if(nums[m]+nums[n]+nums[n+1]+nums[n+2] > target) break; //×îС±Ètarget´ó
if(nums[m]+nums[n]+nums[numsSize-1]+nums[numsSize-2] < target) continue;
i = n+1;
j = numsSize-1;
while( i < j ){
sum = nums[m]+nums[n]+nums[i]+nums[j];
if(sum==target){
*(p+size) = (int*)malloc(sizeof(int)*4);
p[size][0] = nums[m]; p[size][1] = nums[n];
p[size][2] = nums[i]; p[size][3] = nums[j];
size++;
while( nums[i]==nums[i+1]) i++;
i++;
while( nums[j]==nums[j-1]) j--;
j--;
}else if(sum<target){
while( nums[i]==nums[i+1]) i++;
i++;
}else{
while( nums[j]==nums[j-1]) j--;
j--;
}
}
while(nums[n]==nums[n+1]) n++;
}
while(nums[m] == nums[m+1]) m++;
}
*returnSize = size;
return p;
}
int main()
{
int s[6] = {1,0,-1,0,-2,2};
int returnSize;
int **p;
p = fourSum(s,6,0,&returnSize);
for( int i = 0; i < returnSize; i++ ){
printf("[%d,%d,%d,%d]\n",p[i][0],p[i][1],p[i][2],p[i][3]);
}
}