当前位置: 首页 > news >正文

216. 组合总和 III - 力扣(LeetCode)

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

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

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

输入示例

k = 3, n = 7

输出示例

[[1,2,4]]

解题思路
在这里插入图片描述

解题代码

class Solution {List<List<Integer>> ans = new ArrayList<>();Deque<Integer> path = new ArrayDeque<>();public List<List<Integer>> combinationSum3(int k, int n) {backtrack(n, 0, 1, k);return ans;}public void backtrack(int targetSum, int sum, int begin, int k) {// 剪枝if(sum > targetSum) {return;}// 终止条件if(path.size() == k) {// 判断是否满足条件if(targetSum == sum) {// 收集结果ans.add(new ArrayList<Integer>(path));return;}}// 剪枝:9 - (k - path.size()) + 1for(int i = begin; i <= 9 - (k - path.size()) + 1; i++) {path.addLast(i);sum += i;backtrack(targetSum, sum, i+1, k);sum -= i;path.removeLast();}}
}
http://www.lryc.cn/news/286299.html

相关文章:

  • LeetCode-题目整理【5】:O(1) 时间插入、删除和获取随机元素
  • 服务器感染了.wis[[Rast@airmail.cc]].wis勒索病毒,如何确保数据文件完整恢复?
  • ContentNegotiationManagerFactoryBean 内容协商
  • html css js 开发一个猜数字游戏
  • HDD 东山再起,单块 30TB 起步新品想要颠覆储存行业
  • 【网络安全】-基本工具msf
  • Vue3的ref和reactive
  • Flink编程——风险欺诈检测
  • Day37 贪心算法 part06 738. 单调递增的数字 968. 监控二叉树
  • SpringBoot Redis入门(四)——Redis单机、哨兵、集群模式
  • 获取数组中的第一个、第二个、第三个......元素
  • 前端面试题(持续更新~~)
  • ubuntu下无法访问和ping通github的一种解决方法
  • C#,入门教程(28)——文件夹(目录)、文件读(Read)与写(Write)的基础知识
  • 开源大数据集群部署(六)Keytab文件生成
  • 图神经网络X项目|基于图神经网络的电商行为的预测(5%)
  • 仰暮计划|“说是操场,那就是个土坡,我们在那儿上边种种树啊,拔拔草,有的时候还会有同学来喂喂羊啥的,这都是我们的娱乐”
  • Java【代码 16】将word、excel文件转换为pdf格式和将pdf文档转换为image格式工具类分享
  • 8亿日活的抖音,用“自我设限”谋求长期主义
  • Final Cut Pro v10.7.1中文版 专业级视频剪辑软件 兼容M
  • Chrome扩展之通信
  • Appium 环境配置
  • 前端JavaScript篇之Javscript数组的常用方法有哪些?JavaScript判断数组的方式有哪些?
  • 【Spring Boot 3】【Redis】基本数据类型操作
  • [MySQL]关于表的增删改查
  • 编译和链接(翻译环境:预编译+编译+汇编+链接​、运行环境)
  • 洛谷 P1364 医院设置
  • JAVAEE初阶 网络编程(三)
  • Linux 的提示符太长了,帮你精简一下
  • nvm, node.js, npm, yarn 安装配置