news 2026/5/26 4:41:57

js.39. 组合总和

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
js.39. 组合总和

链接: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

思路:

利用回溯的思想来解决这道题。

我的想法是把每次遍历过的数字放在overlist中保存,

然后去递归。combinationSum(candidates.slice(i), target - candidates[i], [...overList])

代码:

/** * @param {number[]} candidates * @param {number} target * @return {number[][]} */ var combinationSum = function(candidates, target, overList = []) { let result = []; candidates.sort((a,b)=>a-b); for (let i = 0; i < candidates.length; i++) { if(candidates[i] > target) { continue; }else if(candidates[i] == target) { target = target - candidates[i]; overList.push(candidates[i]); break; } overList.push(candidates[i]) let temp = combinationSum(candidates.slice(i), target - candidates[i], [...overList]); result.push(...temp); overList.pop(); } if(target == 0) result.push(overList); return result; };

题解:

var combinationSum = function(candidates, target) { const ans = []; const dfs = (target, combine, idx) => { if (idx === candidates.length) { return; } if (target === 0) { ans.push(combine); return; } // 直接跳过 dfs(target, combine, idx + 1); // 选择当前数 if (target - candidates[idx] >= 0) { dfs(target - candidates[idx], [...combine, candidates[idx]], idx); } } dfs(target, [], 0); return ans; };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/26 4:41:17

NX UG 12.0 安装教程:安全获取 + 避坑指南,零基础也能搞定

从事机械设计、模具开发的从业者&#xff0c;对 NX UG 12.0 这款软件一定不陌生&#xff0c;它凭借强大的建模、装配和仿真功能&#xff0c;成为工业设计领域的实用工具。 想要顺利上手这款软件&#xff0c;安全获取安装包和掌握正确安装步骤很关键。安装时建议选择英文路径&a…

作者头像 李华
网站建设 2026/5/25 12:35:41

RN Navigation vs Vue Router:从架构底层到工程实践的深度对比

[toc] 前言&#xff1a;这不是“谁更好”&#xff0c;而是“谁解决的问题不同” 很多团队在同时做 Web 和 RN 项目时&#xff0c;都会下意识问一句&#xff1a;Vue Router 这套东西&#xff0c;在 RN 里能不能也照着来&#xff1f;如果你只是做 Demo&#xff0c;答案是「看起来…

作者头像 李华
网站建设 2026/5/26 0:38:38

廊坊的婚介所靠谱吗?

我叫林晓阳&#xff0c;28岁&#xff0c;廊坊某科技公司程序员。三年前在相亲角遇到现在的丈夫&#xff0c;但那次经历让我对婚恋市场产生了深刻的认知。那年我抱着试试看的心态&#xff0c;走进了当地最大的婚介所。接待我的姑娘笑容甜美&#xff0c;递来一份精心设计的问卷&a…

作者头像 李华
网站建设 2026/5/26 5:50:57

新能源与燃油汽车对比数据可视化分析

新能源与燃油汽车对比数据可视化分析 1. 项目概述 本项目旨在通过数据挖掘技术,深入分析中国汽车市场中新能源汽车(EV)与传统燃油汽车(Gasoline)的竞争格局、销售趋势及关键影响因素。系统集成了数据预处理、探索性数据分析(EDA)、机器学习销量预测模型以及交互式Web可…

作者头像 李华
网站建设 2026/5/26 8:26:57

37、UNIX系统用户管理与支持全攻略

UNIX系统用户管理与支持全攻略 1. 用小事留下大印象 在与用户的交互中,一些看似微不足道的小事往往能给用户留下深刻的印象。以下是几个具体的方法: 1.1 倾听用户 作为管理员,日常工作总是十分繁忙,任务清单上总有做不完的事情。无论是在走廊上偶遇用户,还是用户打电话…

作者头像 李华
网站建设 2026/5/26 5:54:58

38、UNIX系统用户管理与故障处理全攻略

UNIX系统用户管理与故障处理全攻略 1 UNIX系统中的故障类型及时间预估 在使用UNIX服务器时,故障停机是难以避免的情况,而且要配合用户的使用时间来安排故障处理往往颇具挑战。常见的故障类型有以下三种: - 定期计划故障 :在生产环境中,这些是固定的停机时间,所有用户…

作者头像 李华