- Notifications
You must be signed in to change notification settings - Fork 116
/
Copy pathfour_sum.go
37 lines (35 loc) · 736 Bytes
/
four_sum.go
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
package four_sum
import (
"sort"
)
funcfourSum(nums []int, targetint) [][]int {
sort.Ints(nums)
varret [][]int
fori:=0; i<len(nums)-3; i++ {
ifi>0&&nums[i-1] ==nums[i] {
continue
}
forj:=i+1; j<len(nums)-2; j++ {
ifj>i+1&&nums[j-1] ==nums[j] {
continue
}
left, right:=j+1, len(nums)-1
forleft<right {
ifleft>j+1&&nums[left-1] ==nums[left] {
left++
continue
}
ifnums[i]+nums[j]+nums[left]+nums[right] ==target {
ret=append(ret, []int{nums[i], nums[j], nums[left], nums[right]})
left++
right--
} elseifnums[i]+nums[j]+nums[left]+nums[right] <target {
left++
} else {
right--
}
}
}
}
returnret
}