mirror of
https://github.com/halfrost/LeetCode-Go.git
synced 2025-07-05 00:25:22 +08:00
65 lines
1.3 KiB
Go
65 lines
1.3 KiB
Go
package leetcode
|
|
|
|
import "sort"
|
|
|
|
// 解法一
|
|
func subsets(nums []int) [][]int {
|
|
c, res := []int{}, [][]int{}
|
|
for k := 0; k <= len(nums); k++ {
|
|
generateSubsets(nums, k, 0, c, &res)
|
|
}
|
|
return res
|
|
}
|
|
|
|
func generateSubsets(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++ {
|
|
c = append(c, nums[i])
|
|
generateSubsets(nums, k, i+1, c, res)
|
|
c = c[:len(c)-1]
|
|
}
|
|
return
|
|
}
|
|
|
|
// 解法二
|
|
func subsets1(nums []int) [][]int {
|
|
res := make([][]int, 1)
|
|
sort.Ints(nums)
|
|
for i := range nums {
|
|
for _, org := range res {
|
|
clone := make([]int, len(org), len(org)+1)
|
|
copy(clone, org)
|
|
clone = append(clone, nums[i])
|
|
res = append(res, clone)
|
|
}
|
|
}
|
|
return res
|
|
}
|
|
|
|
// 解法三:位运算的方法
|
|
func subsets2(nums []int) [][]int {
|
|
if len(nums) == 0 {
|
|
return nil
|
|
}
|
|
res := [][]int{}
|
|
sum := 1 << uint(len(nums))
|
|
for i := 0; i < sum; i++ {
|
|
stack := []int{}
|
|
tmp := i // i 从 000...000 到 111...111
|
|
for j := len(nums) - 1; j >= 0; j-- { // 遍历 i 的每一位
|
|
if tmp&1 == 1 {
|
|
stack = append([]int{nums[j]}, stack...)
|
|
}
|
|
tmp >>= 1
|
|
}
|
|
res = append(res, stack)
|
|
}
|
|
return res
|
|
}
|