算法--js--组合总和

题:给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target ,找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 ,并以列表形式返回。你可以按 任意顺序 返回这些组合。candidates 中的 同一个 数字可以 无限制重复被选取 。如果至少一个数字的被选数量不同,则两种组合是不同的。 对于给定的输入,保证和为 target 的不同组合数少于 150 个。
1 <= candidates.length <= 30
2 <= candidates[i] <= 40
candidates 的所有元素 互不相同
1 <= target <= 40

javascript 复制代码
function combinationSum(candidates, target) {
    const result = [];
    candidates.sort((a, b) => a - b); // 先排序方便剪枝
    
    const backtrack = (path, start, remain) => {
        if (remain === 0) {
            result.push([...path]); // 深拷贝当前组合
            return;
        }
        for (let i = start; i < candidates.length; i++) {
            if (candidates[i] > remain) break; // 剪枝:当前值超过剩余值
            path.push(candidates[i]);
            backtrack(path, i, remain - candidates[i]); // 允许重复使用当前元素
            path.pop(); // 回溯
        }
    };
  
    backtrack([], 0, target);
    return result;
}

console.log('combinationSum==>', combinationSum([2,3,5], 8)); // combinationSum==>[[2,2,2,2],[2,3,3],[3,5]]

算法核心:

排序剪枝

先对数组排序,当发现 candidates[i] > remain 时直接终止循环,避免无效递归。

回溯模板

path 记录当前组合路径

start 控制遍历起点,避免重复组合(如 [2,3,2] 和 [3,2,2])

remain 表示剩余需要凑的值

允许重复使用元素

递归时传递 i 而非 i+1,允许元素被重复选取。

时间复杂度:

最坏情况为 O(2^n),但题目保证组合数少于 150 个,实际性能优异。

优化点:

• 通过排序和剪枝减少递归深度

• 深拷贝避免引用问题

• 通过 start 参数避免重复组合

相关推荐
We་ct3 分钟前
深度剖析浏览器跨域问题
开发语言·前端·浏览器·跨域·cors·同源·浏览器跨域
风筝在晴天搁浅4 分钟前
字节高频题 小于n的最大数
算法
LabVIEW开发6 分钟前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序
AI科技星11 分钟前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
风筝在晴天搁浅13 分钟前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表
王老师青少年编程27 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【贪心与二分判定】:数列分段 Section II
c++·算法·贪心·csp·信奥赛·二分判定·数列分段 section ii
weixin_4277716128 分钟前
前端调试隐藏元素
前端
threelab40 分钟前
Three.js 代码云效果 | 三维可视化 / AI 提示词
开发语言·javascript·人工智能
V搜xhliang02461 小时前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
汉克老师1 小时前
GESP2025年3月认证C++五级( 第三部分编程题(2、原根判断))
c++·算法·模运算·gesp5级·gesp五级·原根·分解质因数