码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 组合总和III(Lc216)——剪枝+回溯


    找出所有相加之和为 n 的 k 个数的组合,且满足下列条件:

    • 只使用数字1到9
    • 每个数字 最多使用一次 

    返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。

    示例 1:

    输入: k = 3, n = 7
    输出: [[1,2,4]]
    解释:
    1 + 2 + 4 = 7
    没有其他符合的组合了。

    示例 2:

    输入: k = 3, n = 9
    输出: [[1,2,6], [1,3,5], [2,3,4]]
    解释:
    1 + 2 + 6 = 9
    1 + 3 + 5 = 9
    2 + 3 + 4 = 9
    没有其他符合的组合了。

    示例 3:

    输入: k = 4, n = 1
    输出: []
    解释: 不存在有效的组合。
    在[1,9]范围内使用4个不同的数字,我们可以得到的最小和是1+2+3+4 = 10,因为10 > 1,没有有效的组合。
    

    提示:

    • 2 <= k <= 9
    • 1 <= n <= 60

    问题简要描述:返回所有的有效组合的列表

    细节阐述:

    1.  dfs(i,s),表示当前枚举到数字 i,还剩下和为 s 的数字需要枚举

    Java

    1. class Solution {
    2. List> ans = new ArrayList<>();
    3. List t = new ArrayList<>();
    4. int k;
    5. public List> combinationSum3(int k, int n) {
    6. this.k = k;
    7. dfs(1, n);
    8. return ans;
    9. }
    10. void dfs(int i, int s) {
    11. if (s == 0) {
    12. if (t.size() == k) {
    13. ans.add(new ArrayList<>(t));
    14. }
    15. return;
    16. }
    17. if (i > 9 || i > s || t.size() >= k) {
    18. return;
    19. }
    20. t.add(i);
    21. dfs(i + 1, s - i);
    22. t.remove(t.size() - 1);
    23. dfs(i + 1, s);
    24. }
    25. }

     Python3

    1. class Solution:
    2. def combinationSum3(self, k: int, n: int) -> List[List[int]]:
    3. def dfs(i: int, s: int):
    4. if s == 0:
    5. if len(t) == k:
    6. ans.append(t[:])
    7. return
    8. if i > 9 or i > s or len(t) >= k:
    9. return
    10. t.append(i)
    11. dfs(i + 1, s - i)
    12. t.pop()
    13. dfs(i + 1, s)
    14. t = []
    15. ans = []
    16. dfs(1, n)
    17. return ans

    TypeScript

    1. function combinationSum3(k: number, n: number): number[][] {
    2. let ans: number[][] = [];
    3. let t: number[] = [];
    4. const dfs = (i: number, s: number) => {
    5. if (s == 0) {
    6. if (t.length == k) {
    7. ans.push(t.slice());
    8. }
    9. return;
    10. }
    11. if (i > 9 || i > s || t.length >= k) {
    12. return;
    13. }
    14. t.push(i);
    15. dfs(i + 1, s - i);
    16. t.pop();
    17. dfs(i + 1, s);
    18. }
    19. dfs(1, n);
    20. return ans;
    21. };

  • 相关阅读:
    华为云HECS服务器下docker可视化(portainer)
    Java高级-注解
    苹果悄悄推出了一个改变一切的新银行杀手储蓄账户
    什么情况下mysql 会索引失效?
    playwright 一些方法解决cloudflare防护页的问题
    servlet实现登录功能【当用户当前未登陆,跳转登录页面才能访问,若已经登录了,才可以直接访问】
    大家在日常工作中有哪些非常好用的在线办公软件?
    【LeetCode】66. 加一
    10分钟实现dotnet程序在linux下的自动部署
    解析java中的clone方法
  • 原文地址:https://blog.csdn.net/qq_51626500/article/details/138033975
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号