news 2026/3/26 4:03:50

算法题-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/3/23 2:29:05

Linux 系统下 Oracle AI Database 26ai 环境部署全解析

Oracle AI Database 26ai 作为融合 AI 能力的数据平台&#xff0c;正受到数据库管理员和 AI 开发人员的广泛关注。在开发测试场景中&#xff0c;无需构建复杂的高可用架构&#xff0c;通过精简部署流程&#xff0c;单机环境即可快速体验其核心 AI 特性。本文将系统讲解在 Linux…

作者头像 李华
网站建设 2026/3/24 10:37:20

RMBG-2.0轻量模型原理简析:如何在小参数量下实现发丝级分割

RMBG-2.0轻量模型原理简析&#xff1a;如何在小参数量下实现发丝级分割 1. 为什么你需要一个“能看清头发”的抠图工具 你有没有试过用传统抠图工具处理一张带飘逸发丝的证件照&#xff1f;边缘毛躁、半透明区域糊成一片、发丝和背景粘连——最后不得不花半小时手动擦除&…

作者头像 李华
网站建设 2026/3/24 13:44:52

小白友好!Nano-Banana极简纯白风格入门指南,3步出效果

小白友好&#xff01;Nano-Banana极简纯白风格入门指南&#xff0c;3步出效果 你是不是也遇到过这些情况&#xff1f; 想给新设计的服装做一张专业级展示图&#xff0c;但不会用PS&#xff0c;更搞不定3D建模软件&#xff1b;看到别人生成的爆炸图、技术蓝图惊艳不已&#xf…

作者头像 李华
网站建设 2026/3/24 4:14:18

Swin2SR交互指南:左侧面板上传与右侧结果查看

Swin2SR交互指南&#xff1a;左侧面板上传与右侧结果查看 1. 这不是普通放大&#xff0c;是AI显微镜在工作 你有没有试过把一张模糊的截图、马赛克严重的表情包&#xff0c;或者AI生成后只有512像素的小图&#xff0c;直接拉大到打印尺寸&#xff1f;结果往往是——满屏锯齿、…

作者头像 李华