组合 (Python)

LeetCode链接

回溯

class Solution:
    def combine(self, n: int, k: int) -> List[List[int]]:
        '''
        为了不重复 需要按照一定的顺序迭代
        例 n = 4 k = 2
        第一个数  第二个数
        1        [2, 3, 4]
        2        [3, 4]
        3        [4]
        4        []

        循环 + 递归
        '''
        res_list = []
        path = []
        def dfs(begin):
            # path 记录递归路径上的数字
            # 当path长度达到k时 终止递归
            if len(path) == k:
                # 存储一个副本
                res_list.append(path[:])
                return
            # 循环列举第一个数的所有选择
            for i in range(begin, n + 1):
                path.append(i)
                # 第一个数确定后 向下递归
                # 下一层的开始数字为 第一个数 + 1
                dfs(i + 1)
                # 每轮递归完成后 清理path
                # 开启第二轮循环
                path.pop()
        dfs(1)
        return res_list

回溯 + 剪枝

class Solution:
    def combine(self, n: int, k: int) -> List[List[int]]:
        res_list = []
        path = []
        def dfs(begin):
            if len(path) == k:
                res_list.append(path[:])
                return
            # 此处加上了剪枝逻辑 对每轮循环的上界进行优化
            # 举例 n = 7  k = 4
            # 当len(path) == 1 还需 3 个元素  上界为 5
            # 当len(path) == 2 还需 2 个元素  上界为 6

            # 上界 + 剩余元素数 - 1 =  n
            # 剩余元素数 k - len(path)
            # 上界  n - (k - len(path)) + 1
            for i in range(begin, n - (k - len(path)) + 1 + 1):
                path.append(i)
                dfs(i + 1)
                path.pop()
        dfs(1)
        return res_list
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值