【LeetCode 77. 组合】

1. 题目

2. 分析

本题有个难点在于如何保存深搜得到的结果?总结了一下,深搜处理的代码,关于返回值有三大类。

第一类:层层传递,将最深层的结果传上来;这类题有:【反转链表

第二类:每层都返回值,迭代更新;这类题有【二叉树最大深度

第三类:使用全局变量,将结果写到变量中保存。

本题的深搜代码则需要配合第三类来解决。

3. 代码

python 复制代码
class Solution:
    res = []
    def combine(self, n: int, k: int) -> List[List[int]]:
        cnt = 0
        idx = 1
        self.res = []
        tmp = []
        self.dfs(cnt, n, k, idx, tmp)
        return self.res

    def dfs(self, cnt, n, k, idx, tmp):
		# 这里需要注意,是n+1, 否则最后一个结果拿不到。
		# 一定要结合代码输出快速的定位问题
        if idx > n+1: 
            return    
        if cnt == k:
            print(tmp)
            self.res.append(tmp[:])
        elif cnt < k:
            tmp.append(idx)
            self.dfs(cnt+1, n, k, idx+1, tmp)
            del tmp[-1]
            self.dfs(cnt, n, k, idx+1, tmp)
相关推荐
C++ 老炮儿的技术栈12 分钟前
什么是函数重载?为什么 C 不支持函数重载,而 C++能支持函数重载?
c语言·开发语言·c++·qt·算法
yychen_java1 小时前
R-tree详解
java·算法·r-tree
MarkHard1231 小时前
Leetcode (力扣)做题记录 hot100(62,64,287,108)
算法·leetcode·职场和发展
一只鱼^_2 小时前
牛客练习赛138(首篇万字题解???)
数据结构·c++·算法·贪心算法·动态规划·广度优先·图搜索算法
一只码代码的章鱼2 小时前
Spring的 @Validate注解详细分析
前端·spring boot·算法
邹诗钰-电子信息工程2 小时前
嵌入式自学第二十一天(5.14)
java·开发语言·算法
↣life♚3 小时前
从SAM看交互式分割与可提示分割的区别与联系:Interactive Segmentation & Promptable Segmentation
人工智能·深度学习·算法·sam·分割·交互式分割
zqh176736464693 小时前
2025年阿里云ACP人工智能高级工程师认证模拟试题(附答案解析)
人工智能·算法·阿里云·人工智能工程师·阿里云acp·阿里云认证·acp人工智能
fie88893 小时前
用模型预测控制算法实现对电机位置控制仿真
算法
Kent_J_Truman3 小时前
【交互 / 差分约束】
算法