LeetCode:216.组合总和III

news/2025/1/13 13:00:11/

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的!
代码随想录

LeetCode:216.组合总和III
找出所有相加之和为 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,没有有效的组合。

和上一题类似,只是多加了一个和的限制

java">	public List<List<Integer>> combinationSum3(int k, int n) {List<List<Integer>> res = new ArrayList<>();backtracking(k, n, 1, 0, new ArrayList<>(), res);return res;}private void backtracking(int k, int n, int startIndex, int sum, List<Integer> path, List<List<Integer>> res) {// sum作为参数的话会快很多// int sum = path.stream().mapToInt(Integer::intValue).sum();if (sum > n)return;if (path.size() == k && sum == n) {res.add(new ArrayList(path));return;}for (int i = startIndex; i <= 9 - (k - path.size()) + 1; i++) {path.add(i);sum += i;backtracking(k, n, i + 1, sum, path, res);sum -= i;path.removeLast();}}

http://www.ppmy.cn/news/1562812.html

相关文章

EasyExcel上传校验文件错误信息放到文件里以Base64 返回给前端

产品需求&#xff1a; 前端上传个csv 或 excel 文件&#xff0c;文件共4列&#xff0c;验证文件大小&#xff0c;类型&#xff0c;文件名长度&#xff0c;文件内容&#xff0c;如果某行某个单元格数据验证不通过&#xff0c;就把错误信息放到这行第五列&#xff0c;然后把带有…

STM32 物联网智能家居 (一) 方案设计STM32+ESP8266+TCP/UDP/MQTT

STM32 物联网智能家居 (一) 方案设计STM32ESP8266TCP/UDP/MQTT 下面我们要开展物联网智能家居的博客专栏&#xff0c;该专栏我们会将STM32各种外设模块I2c、Usart、Wifi、ESP8266、分层编程思想以及调试的方法融入到整个专栏中&#xff0c;让你从一个单片机小白&#xff0c;进…

浅聊MySQL中的LBCC和MVCC

MySQL中的LBCC&#xff08;Lock-Based Concurrency Control&#xff0c;基于锁的并发控制&#xff09;和MVCC&#xff08;Multi-Version Concurrency Control&#xff0c;多版本并发控制&#xff09;是两种不同的并发控制机制&#xff0c;它们在实现方式、作用以及应用场景上存…

MySQL教程之:获取有关数据库和表的信息

如果您忘记了数据库或表的名称&#xff0c;或者给定表的结构是什么&#xff08;例如&#xff0c;它的列叫什么&#xff09;怎么办&#xff1f;MySQL通过几个语句来解决这个问题&#xff0c;这些语句提供了有关它支持的数据库和表的信息。 您之前看过SHOW DATABASES&#xff0c…

隐私计算,构建安全的未来数据空间

大数据产业创新服务媒体 ——聚焦数据 改变商业 在医疗领域&#xff0c;不同医院之间需要共享患者数据&#xff0c;以提供更全面准确的诊断和治疗方案。 传统的数据处理方式通常是数据经过转换隐藏重要数据后再进行分析&#xff0c;虽然可以保护数据隐私&#xff0c;但在数据源…

Guilite字库工具

目录 前言 使用方法 离线字库解析 工具链接 前言 最近通过Qt写了一个Guilite字库工具&#xff0c;相比原始工具&#xff0c;主要有以下几个优点&#xff1a; &#xff08;1&#xff09;支持同时生成多套字库 &#xff08;2&#xff09;支持离线字库生成 &#xff08;3&a…

Hive SQL必刷练习题:连续问题 间断连续

问题描述&#xff1a; 1&#xff09; 连续问题&#xff1a;找出连续三天&#xff08;或者连续几天的啥啥啥&#xff09;。 2&#xff09; 间断连续&#xff1a;统计各用户连续登录最长天数&#xff0c;间断一天也算连续&#xff0c;比如1、3、4、6也算登陆了6天 问题分析&am…

(长期更新)《零基础入门 ArcGIS(ArcScene) 》实验七----城市三维建模与分析(超超超详细!!!)

城市三维建模与分析 三维城市模型已经成为一种非常普遍的地理空间数据资源,成为城市的必需品,对城市能化管理至关重要。语义信息丰富的三维城市模型可以有效实现不同领域数据与IS相信息的高层次集成及互操作,从而在城市规划、环境模拟、应急响应和辅助决策等众多领域公挥作用、…