
216 组合总和 III(递归)
递归函数定义:定义一个递归函数,接受当前的选择情况:已选数字的数量、当前的和、当前数字的起始位置、结果列表、以及中间记录列表。 遍历数字:在函数中,遍历从起始位置到 9 的数字。 剪枝条件:检查当前选的数字是否超过剩余的和的限制。如果超过,则跳过该数字。 选择数字并递归:如果满足条件,选择该数字,更新中间列表,递归调用函数。 撤销选择:递归返回后,撤销选择,恢复中间列表。 结果收集:当满足 k 个数字和为 n 的条件时,将中间列表加入结果。
发布日期:2021-05-07 21:53:43
浏览次数:16
分类:精选文章
本文共 1228 字,大约阅读时间需要 4 分钟。
为了解决这个问题,我们需要找出所有相加之和为 n 的 k 个数的组合。组合中只允许含有 1 到 9 的正整数,并且每种组合中不存在重复的数字。
方法思路
我们可以使用递归的方法来解决这个问题。递归的思路是,先处理当前的数字,然后递归处理剩下的部分。具体步骤如下:
解决代码
from typing import Listclass Solution: def combinationSum3(self, k: int, n: int) -> List[List[int]]: res = [] path = [] def dfs(start, current_sum): if len(path) == k and current_sum == n: res.append(path.copy()) return for i in range(start, 10): if current_sum + i > n: continue if len(path) < k and (current_sum + i + (9 - i) * (k - len(path) - 1) < n): continue path.append(i) dfs(i + 1, current_sum + i) path.pop() dfs(1, 0) return res
代码解释
- 递归函数 dfs:这是核心的递归函数,负责进行深度优先搜索。它接受当前的起始数字和当前的和。
- 路径记录:使用
path
列表来记录当前的组合路径,确保每个组合中的数字不重复。 - 剪枝条件:在递归过程中,检查当前路径是否超过剩余和的限制,避免无效递归。
- 结果收集:当满足条件时,将当前路径添加到结果列表中。
通过这种方法,我们可以高效地找到所有满足条件的组合。
发表评论
最新留言
逛到本站,mark一下
[***.202.152.39]2025年04月13日 15时27分53秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
【Oozie】(三)Oozie 使用实战教学,带你快速上手!
2019-03-05
师兄面试遇到这条 SQL 数据分析题,差点含泪而归!
2019-03-05
C语言的数值溢出问题(上)
2019-03-05
函数指针的典型应用-计算函数的定积分(矩形法思想)
2019-03-05
8051单片机(STC89C52)以定时器中断模式实现两倒计时器异步计时
2019-03-05
用 wxPython 打印你的 App
2019-03-05
vue项目通过vue.config.js配置文件进行proxy反向代理跨域
2019-03-05
android:使用audiotrack 类播放wav文件
2019-03-05
聊聊我的五一小假期
2019-03-05
LeetCode:28. 实现 strStr()——————简单
2019-03-05
Lionheart万汇:布林线双底形态分析技巧
2019-03-05
数据库三个级别封锁协议
2019-03-05
ACM/NCPC2016 C Card Hand Sorting(upc 3028)
2019-03-05
方法重写
2019-03-05
Java求逆波兰表达式的结果(栈)
2019-03-05
ubuntu学习笔记-常用文件、命令以及作用(hosts、vim、ssh)
2019-03-05
SLAM学习笔记-求解视觉SLAM问题
2019-03-05
普歌-允异团队-HashMap面试题
2019-03-05
还在一个一个手动安装虚拟机吗?Cobbler自动部署装机一键最小化安装打把游戏就好了
2019-03-05