【LeetCode热题100(56/100)】组合总和

题目地址: 链接

思路: 递归回溯

js 复制代码
/**
 * @param {number[]} candidates
 * @param {number} target
 * @return {number[][]}
 */
var combinationSum = function(candidates, target) {
    let n = candidates.length
    let ans = [];
    const dfs = (idx, sum, arr) => {
        if(sum > target) return;
        if(sum === target) {
            ans.push(arr);
            return;
        }

        for(let i = idx; i < n; i ++) {
            dfs(i, sum + candidates[i], [...arr, candidates[i]]);
        }
    }

    dfs(0, 0, []);
    return ans;
};
相关推荐
WBluuue1 分钟前
Codeforces 1088 Div1+2(ABC1C2DEF)
c++·算法
蓝色的杯子9 分钟前
Python面试30分钟突击掌握-LeetCode3-Linked list
python·leetcode·面试
像素猎人10 分钟前
map<数据类型,数据类型> mp和unordered_map<数据类型,数据类型> ump的讲解,蓝桥杯OJ4567最大数目
c++·算法·蓝桥杯·stl·map
Narrastory11 分钟前
Note:强化学习(一)
人工智能·算法·强化学习
沐雪轻挽萤23 分钟前
1. C++17新特性-序章
java·c++·算法
郝学胜-神的一滴31 分钟前
从链表到二叉树:树形结构的入门与核心性质解析
数据结构·c++·python·算法·链表
csdn_aspnet37 分钟前
C语言 (QuickSort using Random Pivoting)使用随机枢轴的快速排序
c语言·算法·排序算法
玖釉-37 分钟前
深入解析 meshoptimizer:基于 meshopt_computeSphereBounds 的层级包围球构建与 DAG 优化
c++·算法·图形渲染
语戚1 小时前
力扣 494. 目标和 —— 回溯 & 动态规划双解法全解(Java 实现)
java·算法·leetcode·动态规划·力扣·dp·回溯
北顾笙9801 小时前
day23-数据结构力扣
数据结构·算法·leetcode