mirror of
https://github.com/halfrost/LeetCode-Go.git
synced 2025-07-04 16:12:47 +08:00
36 lines
852 B
Go
36 lines
852 B
Go
package leetcode
|
|
|
|
import (
|
|
"fmt"
|
|
"sort"
|
|
)
|
|
|
|
func subsetsWithDup(nums []int) [][]int {
|
|
c, res := []int{}, [][]int{}
|
|
sort.Ints(nums) // 这里是去重的关键逻辑
|
|
for k := 0; k <= len(nums); k++ {
|
|
generateSubsetsWithDup(nums, k, 0, c, &res)
|
|
}
|
|
return res
|
|
}
|
|
|
|
func generateSubsetsWithDup(nums []int, k, start int, c []int, res *[][]int) {
|
|
if len(c) == k {
|
|
b := make([]int, len(c))
|
|
copy(b, c)
|
|
*res = append(*res, b)
|
|
return
|
|
}
|
|
// i will at most be n - (k - c.size()) + 1
|
|
for i := start; i < len(nums)-(k-len(c))+1; i++ {
|
|
fmt.Printf("i = %v start = %v c = %v\n", i, start, c)
|
|
if i > start && nums[i] == nums[i-1] { // 这里是去重的关键逻辑,本次不取重复数字,下次循环可能会取重复数字
|
|
continue
|
|
}
|
|
c = append(c, nums[i])
|
|
generateSubsetsWithDup(nums, k, i+1, c, res)
|
|
c = c[:len(c)-1]
|
|
}
|
|
return
|
|
}
|