leetcode

77. Combinations.go

2019-03-23  本文已影响0人  AnakinSun

回溯算法

func combine(n int, k int) [][]int {
    var res [][]int
    helper(&res, []int{}, 1, n, k)
    return res
}

func helper(res *[][]int, coms []int, start int, n int, k int) {
    if k == 0 {
        tmp := []int{}
        tmp = append(tmp, coms...)
        *res = append(*res, tmp)
        return
    }
    for i := start; i <= n; i++ {
        coms = append(coms, i)
        helper(res, coms, i+1, n, k-1)
        coms = coms[:len(coms)-1]
    }
}
上一篇 下一篇

猜你喜欢

热点阅读