leetcode 216. 组合总和 III(回溯法)

算法思路:https://leetcode-cn.com/problems/combination-sum-iii/solution/hua-jie-suan-fa-216-zu-he-zong-he-iii-by-guanpengc/

python代码:

class Solution():
    def combinationSum3(self, k, n):
        """
        :type k: int
        :type n: int
        :rtype: List[List[int]]
        """
        self.res = []
        self.traceBack(k, n, 0, 1, [])
        #print(self.res)
        return self.res
    def traceBack(self, k, n, flag, start, temp):
        if k == 0:
            if n == flag:
                #需拷贝temp,否则同一地址下的内容会被清除
                self.res.append(temp[:]) 
            return None
        for i in range(start, 10, 1):
            temp.append(i)
            self.traceBack(k - 1, n, flag + i, i + 1, temp)
            temp.pop()
                

x = Solution()
x.combinationSum3(3, 9)

go代码:

package main


type result struct {
	res [][]int
}

func combinationSum3(k int, n int) [][]int {
	var this result
	var temp []int
	this.traceBack(k, n, 0, 1, temp)
	//fmt.Println(this.res)
	return this.res
}
//定义结构体result的方法,方便返回最终结果
func (this *result)traceBack(k int, n int, sum int, start int, temp []int)  {
	if k == 0 {
		if n == sum {
			//t开辟新地址存储结果, 否则最后结果长度为k的切片都是同一地址,
			// 切片里的第k个元素会被最后状态覆盖
			var t []int
			t = append(t, temp[:] ...)
			this.res = append(this.res, t)
		}
		return
	}
	for i := start; i < 10; i ++ {
		temp = append(temp, i)
		this.traceBack(k - 1, n, sum + i, i + 1, temp)
		temp =  temp[:len(temp) - 1]
	}
}

func main() {
	combinationSum3(3, 9)
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值