码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LeetCode216组合总和3


    题目描述

      找出所有相加之和为 n 的 k 个数的组合,且满足下列条件:只使用数字1到9。每个数字 最多使用一次。返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。

    解析

      递归加剪枝,搜索长度达到k就可以返回,另外当选择的数之和比n还大的时候就可以不用再搜索了。

    public List> combinationSum3(int k, int n) {
            List> res = new ArrayList<>();
            boolean[] isChosen = new boolean[10];
            List current = new ArrayList<>();
            DFS(res, current, isChosen, 0, k, n, 1);
            return res;
        }
    
        private void DFS(List> res,
                                List current,
                                boolean[] isChosen,
                                int curSum,
                                int k,
                                int n,
                                int start) {
    
            if(current.size() == k) {
                if(curSum == n) {
                    res.add(new ArrayList<>(current));
                }
                return;
            }
    
            for(int i = start; i <= 9 ; i++) {
                if(!isChosen[i]) {
                    current.add(i);
                    curSum += i;
                    if(curSum <= n) {
                        isChosen[i] = true;
                        DFS(res, current, isChosen, curSum, k, n, i + 1);
                    }
                    current.remove(current.size() - 1);
                    curSum -= i;
                    isChosen[i] = false; // 回溯
                }
            }
        }
    

    在这里插入图片描述

  • 相关阅读:
    四、nginx负载均衡[轮询]
    最短路径算法
    LeetCode100题总结【算法】
    JSR303和拦截器
    Selenum八种常用定位(案例解析)
    大屏自适应容器组件-Vue3+TS
    MybatisPlus多表关联分页返回结果异常
    什么叫等响曲线?有什么用?
    Vue学习笔记
    微服务组件之Zuul
  • 原文地址:https://blog.csdn.net/Chisato1021/article/details/139423179
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号