力扣刷题——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,2] 和 [2,1] 只保留一个)

相关推荐
放羊郎8 小时前
基于ORB-SLAM2算法的优化工作
人工智能·算法·计算机视觉
mask哥8 小时前
力扣算法java实现汇总整理(上)
java·算法·leetcode
如果'\'真能转义说9 小时前
OOXML 文档格式剖析:哈希、ZIP结构与识别
xml·算法·c#·哈希算法
2301_809204709 小时前
JavaScript中严格模式use-strict对引擎解析的辅助.txt
jvm·数据库·python
夏日听雨眠9 小时前
数据结构(栈和队列)
数据结构
zjy277779 小时前
mysql如何选择合适的索引类型_mysql索引设计实战
jvm·数据库·python
Aaswk9 小时前
Java Lambda 表达式与流处理
java·开发语言·python
万邦科技Lafite9 小时前
京东item_get接口实战案例:实时商品价格监控全流程解析
java·开发语言·数据库·python·开放api·淘宝开放平台
Cyber4K10 小时前
【Python专项】进阶语法-系统资源监控与数据采集(1)
开发语言·python·php
梦梦代码精10 小时前
BuildingAI 上部署自定义工作流智能体:5 个实用技巧
大数据·人工智能·算法·开源软件