forked from wufenggirl/LeetCode-in-Golang
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path3sum.go
executable file
·57 lines (49 loc) · 935 Bytes
/
3sum.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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
package problem0015
import "sort"
func threeSum(nums []int) [][]int {
// 排序后,可以按规律查找
sort.Ints(nums)
res := [][]int{}
for i := range nums {
if nums[i] > 0 {
break
}
// 避免添加重复的结果
// i>0 是为了防止nums[i-1]溢出
if i > 0 && nums[i] == nums[i-1] {
continue
}
l, r := i+1, len(nums)-1
for l < r {
s := nums[i] + nums[l] + nums[r]
switch {
case s < 0:
// 较小的 l 需要变大
l++
case s > 0:
// 较大的 r 需要变小
r--
default:
res = append(res, []int{nums[i], nums[l], nums[r]})
// 为避免重复添加,l 和 r 都需要移动到不同的元素上。
l, r = next(nums, l, r)
}
}
}
return res
}
func next(nums []int, l, r int) (int, int) {
for l < r {
switch {
case nums[l] == nums[l+1]:
l++
case nums[r] == nums[r-1]:
r--
default:
l++
r--
return l, r
}
}
return l, r
}