力扣刷题——77. 组合

77. 组合

给定两个整数 n 和 k,返回范围 1, n 中所有可能的 k 个数的组合。

你可以按 任何顺序 返回答案。

示例 1:

输入:n = 4, k = 2

输出:

\[2,4\], \[3,4\], \[2,3\], \[1,2\], \[1,3\], \[1,4\],

示例 2:

输入:n = 1, k = 1

输出:\[1]

提示:

1 <= n <= 20

1 <= k <= n

实现代码(Python):

python 复制代码
class Solution:
    def combine(self, n: int, k: int) -> List[List[int]]:
        res=[]
        def backtracking(startidx,path):
            #终止条件:路径长度等于k,找到一个合法组合
            if len(path)==k: 
                res.append(path[:])  #对列表进行复制,而不是加入
                return # 终止当前递归,返回上一层
            
            for i in range(startidx,n+1):
                path.append(i) # 做选择:把当前数加入路径
                backtracking(i+1,path) # 递归:下一轮从i+1开始选
                path.pop() # 回溯:撤销选择,弹出最后一个数,尝试下一个i

        backtracking(1,[]) #调用,初始路径为空
        return res
        

分析

回溯算法三要素为:调用参数和返回值、终止条件、单层处理过程

大致模板:

def backtracking(参数) :

if 终止条件:

存放结果

return

for 选择:本层集合中元素(树中节点孩子的数量就是集合的大小 :

处理节点

backtracking(路径,选择列表) // 递归

回溯,撤销处理结果

当最外层递归的循环遍历完所有可选值,那么回溯就停止了

特别注意!!!!
path: → 创建当前 path 的副本,result 存储的是 "值的快照",不受后续回溯修改影响;因为列表是可变对象,在内存中只有一份。如果直接 append(path),result 中存储的是「指向 path 的引用」,而非当前 path 的值。后续回溯时 path.pop() 会修改这个引用指向的列表,最终 result 中所有元素都会变成空列表 / 最后一次修改的结果。

去重关键:startIndex 控制选择起点,保证组合是升序的,避免重复(比如 1,22,1 只保留一个)

相关推荐
半个落月2 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
zzzzzz3103 小时前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐3 小时前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python
小月土星3 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星3 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试
兵慌码乱14 小时前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
hboot16 小时前
AI工程师第三课 - 机器学习基础
python·scikit-learn·kaggle
To_OC19 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
顾林海21 小时前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程