Leetcode40. 组合总和 II

  • 时间:
  • 来源:互联网
  • 文章标签:

Leetcode40. 组合总和 II

class Solution {

    List<List<Integer>> result = new ArrayList<>();
    List<Integer> path = new ArrayList<>();

    public List<List<Integer>> combinationSum2(int[] candidates, int target) {
        Arrays.sort(candidates);
        backTrack(candidates, target, 0);
        return result;
    }

    /**
     * 回溯查询
     *
     * @param candidates 候选元素
     * @param target     目标值
     * @param start      开始搜索的下标值
     */
    private void backTrack(int[] candidates, int target, int start) {
        if (target == 0) {
            result.add(new ArrayList<>(path));
        }
        for (int i = start; i < candidates.length; i++) {
            // 剪枝
            if (candidates[i] > target) {
                break;
            }
            // 当i大于start,并且下标为i-1和下标为i的数字相同时,需要跳过,避免出现相同的path
            if (i > start && candidates[i - 1] == candidates[i]) {
                continue;
            }
            // 将当前元素添加到path中(破坏现场)
            path.add(candidates[i]);
            backTrack(candidates, target - candidates[i], i + 1);
            // 将当前元素从path中删除(恢复现场),方便后续的递归查找
            path.remove(path.size() - 1);
        }
    }
}

本文链接http://www.taodudu.cc/news/show-1944892.html