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

39. 组合总和

给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target ,找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 ,并以列表形式返回。你可以按 任意顺序 返回这些组合。

candidates 中的 同一个 数字可以 无限制重复被选取 。如果至少一个数字的被选数量不同,则两种组合是不同的。 

对于给定的输入,保证和为 target 的不同组合数少于 150 个。

示例 1:

输入:candidates = [2,3,6,7], target = 7
输出:[[2,2,3],[7]]
解释:
2 和 3 可以形成一组候选,2 + 2 + 3 = 7 。注意 2 可以使用多次。
7 也是一个候选, 7 = 7 。
仅有这两种组合。

示例 2:

输入: candidates = [2,3,5], target = 8
输出: [[2,2,2,2],[2,3,3],[3,5]]

示例 3:

输入: candidates = [2], target = 1
输出: []

提示:

  • 1 <= candidates.length <= 30
  • 2 <= candidates[i] <= 40
  • candidates 的所有元素 互不相同
  • 1 <= target <= 40
public static List<List<Integer>> combinationSum(int[] candidates, int target) {List<List<Integer>> ans = new ArrayList<List<Integer>>();LinkedList<Integer> combine = new LinkedList<Integer>();dfs(candidates, target, ans, combine, 0);return ans;}public static void dfs(int[] candidates, int target, List<List<Integer>> ans, LinkedList<Integer> combine, int index) {if (index == candidates.length) {return;}if (target == 0) {ans.add(new ArrayList<Integer>(combine));return;}dfs(candidates, target, ans, combine, index + 1);if (target - candidates[index] >= 0) {combine.add(candidates[index]);dfs(candidates, target - candidates[index], ans, combine, index);combine.removeLast();}}

http://www.lryc.cn/news/67782.html

相关文章:

  • 100行以内Python能做那些事
  • Android 电源键事件流程分析
  • 游戏搬砖简述-1
  • 多线程基础总结
  • 视频理解AI模型分类与汇总
  • 【Linux】多线程 --- 线程同步与互斥+生产消费模型
  • 17.模型的定义
  • golang 记录交叉编译sqlite的报错信息 go build -ldflags
  • ChatGPT AI使用成本
  • 腾讯云与中电金信发布联合核心方案
  • 老胡的周刊(第090期)
  • 2023-数仓常见问题以及解决方案
  • 没关系,前端还死不了
  • OpenSSL-基于IP或域名生成自签名证书脚本
  • 如何在C#中创建和使用自定义异常
  • 通过systemctl管理服务
  • 面经|小红书经营分析师
  • abpvnext后台工作者使用quartz扩展的一些思路和使用细节记录--(未完待续)
  • 提升应届生职场竞争力:有效策略和关键推动因素
  • PBDB Data Service:List of fossil collections(化石采集记录列表)
  • centos安装SNB服务
  • 课程《JavaWeb基础框架程序设计》考试题下篇——数据库与表单操作用题(人事管理平台的添加员工档案信息的操作题)
  • Linux-初学者系列——篇幅4_系统运行相关命令
  • 无缝集成:利用Requests库轻松实现数据抓取与处理
  • 几种内部排序算法的cpp代码实现与分析
  • 第3天学习Docker-Docker部署常见应用(MySQL、Tomcat、Nginx、Redis、Centos)
  • 给大家介绍四款最受欢迎的抓包神器
  • 解决Reids过期方案 游标遍历清除Redis过期的key
  • K8s基础10——数据卷、PV和PVC、StorageClass动态补给、StatefulSet控制器
  • oracle系统查询~3