news 2026/6/19 23:15:01

算法题-03

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法题-03

组合总数

给你一个无重复元素的整数数组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输出:[]
/** * @param {number[]} candidates * @param {number} target * @return {number[][]} */ var combinationSum = function(candidates, target) { const path = [] const res = [] const backtrack = (startIndex,sum) => { if(sum === target){ res.push([...path]) return } if(sum > target){ return } for(let i = startIndex; i < candidates.length;i++){ const cur = candidates[i] path.push(cur) backtrack(i,sum + cur) path.pop() } } backtrack(0,0) return res };

首先用一个数组path存当前的组合

用一个变量sum记录当前和

从某个起始下标开始选数,由于题目告诉我们同一个数字可以无限制重复被选取,且如果被选取的数量相同则组合是相同的,所以我们要避免出现[2,2,3][3,2,2]同时存在的情况,可以通过后面的递归只能从当前的下表选取从而避免这一情况,

2 → 只能选 2、3、6、7 3 → 只能选 3、6、7

在回溯函数中,注意这么几块

1. 终止条件:和正好等于 target

if (sum === target) { res.push([...path]) // 注意要拷贝 return }

. 2.剪枝:和超过 target,直接返回,这里主要目的的效率提升

if (sum > target) { return }

3. 遍历候选数组

for (let i = startIndex; i < candidates.length; i++) { const cur = candidates[i] // 选择 path.push(cur) // 递归:i 而不是 i+1(允许重复使用) backtrack(i, sum + cur) // 撤销选择(回溯) path.pop() }

注意:

因为数字可以重复使用,backtrack(i, sum + cur),如果写成i + 1,就变成每个数只能用一次了

res.push([...path]),因为path是同一个数组对象,不拷贝的话,后面回溯会把结果全改掉

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/17 4:11:48

经方药食两用服务平台信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】

摘要 随着中医药文化的普及和健康管理意识的提升&#xff0c;经方药食两用服务逐渐成为人们关注的焦点。传统的中医药服务模式存在信息分散、管理效率低、用户体验不佳等问题&#xff0c;亟需通过信息化手段优化服务流程。经方药食两用服务平台信息管理系统的开发旨在整合中医药…

作者头像 李华
网站建设 2026/6/15 15:28:54

Windows热键冲突终极解决方案:3步定位与企业级优化指南

Windows热键冲突终极解决方案&#xff1a;3步定位与企业级优化指南 【免费下载链接】hotkey-detective A small program for investigating stolen hotkeys under Windows 8 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 在Windows系统日常操作中&…

作者头像 李华
网站建设 2026/6/15 15:41:41

ccmusic-database数字音乐发行:独立音乐人上传作品自动获取流派标签

ccmusic-database数字音乐发行&#xff1a;独立音乐人上传作品自动获取流派标签 你是不是也遇到过这样的问题&#xff1a;辛辛苦苦做完一首原创曲子&#xff0c;上传到平台时却卡在“选择流派”这一步&#xff1f;选“独立流行”&#xff0c;怕不够准确&#xff1b;选“另类摇…

作者头像 李华
网站建设 2026/6/18 20:48:42

PDF解析神器QAnything:5步完成文档转换与表格识别

PDF解析神器QAnything&#xff1a;5步完成文档转换与表格识别 1. 为什么PDF解析总是让人头疼&#xff1f; 你有没有遇到过这样的场景&#xff1a;手头有一份几十页的PDF制度文件&#xff0c;需要快速提取关键条款、整理成结构化内容&#xff0c;或者把里面的表格数据导入Exce…

作者头像 李华