Tcdian / keep

今天不想做,所以才去做。
MIT License
5 stars 1 forks source link

39. Combination Sum #321

Open Tcdian opened 3 years ago

Tcdian commented 3 years ago

39. Combination Sum

给定一个 无重复元素 的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。

candidates 中的数字可以无限制重复被选取。

Note

Example 1

Input: candidates = [2,3,6,7], target = 7,
A solution set is:
[
  [7],
  [2,2,3]
]

Example 2

Input: candidates = [2,3,5], target = 8,
A solution set is:
[
  [2,2,2,2],
  [2,3,3],
  [3,5]
]

Constraints

Tcdian commented 3 years ago

Solution

/**
 * @param {number[]} candidates
 * @param {number} target
 * @return {number[][]}
 */
var combinationSum = function(candidates, target) {
    candidates.sort((a, b) => a - b);
    const reuslt = [];
    const part = [];
    backtracking(0);
    return reuslt;

    function backtracking(index) {
        const sum = part.reduce((prev, current) => prev + current, 0);
        if (sum >= target) {
            if (sum === target) {
                reuslt.push([...part]);
            }
            return;
        }
        for (let i = index; i < candidates.length; i++) {
            part.push(candidates[i]);
            backtracking(i);
            part.pop();
        }
    }
};
function combinationSum(candidates: number[], target: number): number[][] {
    candidates.sort((a, b) => a - b);
    const reuslt: number[][] = [];
    const part: number[] = [];
    backtracking(0);
    return reuslt;

    function backtracking(index: number) {
        const sum = part.reduce((prev, current) => prev + current, 0);
        if (sum >= target) {
            if (sum === target) {
                reuslt.push([...part]);
            }
            return;
        }
        for (let i = index; i < candidates.length; i++) {
            part.push(candidates[i]);
            backtracking(i);
            part.pop();
        }
    }
};