Skip to content

Commit

Permalink
Create 0018-4Sum.go solution
Browse files Browse the repository at this point in the history
  • Loading branch information
razer96 committed Jan 17, 2023
1 parent c901198 commit 965c370
Showing 1 changed file with 45 additions and 0 deletions.
45 changes: 45 additions & 0 deletions go/0018-4Sum.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
func fourSum(nums []int, target int) [][]int {
if len(nums) < 4 {
return [][]int{}
}

sort.Ints(nums)

result := make([][]int, 0)

for i, ival := range nums {
if i != 0 && nums[i] == nums[i - 1] {
continue
}

for j := i + 1; j < len(nums) - 1; j++ {
if j != i+1 && nums[j] == nums[j-1] {
continue
}

jval := nums[j]

for l, r := j+1, len(nums) - 1; l < r; {
lval, rval := nums[l], nums[r]

sum := ival + jval + lval + rval
switch {
case sum < target:
l++
case sum > target:
r--
default:
result = append(result, []int{ival, jval, lval, rval})
for ; l < r && nums[l] == nums[l+1]; l++ {
}
for ; l < r && nums[r] == nums[r-1]; r-- {
}
l++
r--
}
}
}
}

return result
}

0 comments on commit 965c370

Please sign in to comment.