【LeetCode题解】39. 组合总和

给定一个无重复元素的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。
candidates 中的数字可以无限制重复被选取。
说明:
所有数字(包括 target)都是正整数。
解集不能包含重复的组合。
示例 1:
输入: candidates = [2,3,6,7], target = 7,
所求解集为:
[
[7],
[2,2,3]
]
示例 2:
输入: candidates = [2,3,5], target = 8,
所求解集为:
[
[2,2,2,2],
[2,3,3],
[3,5]
]

题解:

  • 递归+回溯,有点不是很明白,java应该都是值传递,但是回溯后貌似会改变ret中子List的值,希望了解的解释一下,这里用的是ret.add(new ArrayList(list));
  • 一个很有意思的是ArrayList的remove有 remove(index)返回值是被删除的元素,remove(Object)返回值是布尔类型,但是对于< Integer >的ArrayList默认remove( 4 )是 remove(index = 4),可以用remove(Integer.valueOf(4))调用移除值为4的第一个元素
  • 解集不能包含重复的组合 = sort后 ,选取下一个元素时只能选取当前元素及之后的任一元素,否则会出现重复选取 如 :【2 , 3】 target =5 有【2,3】和【3,2】
class Solution {
    List> ret = new ArrayList<>();
    public List> combinationSum(int[] candidates, int target) {
        Arrays.sort(candidates);
        List list = new ArrayList<>();
        getNum(candidates, target,0, 0, list);
        return ret;
    }
    //index记录当前位置,选取下一个元素时只能选取当前元素及之后的任一元素
    void getNum(int[] c, int target ,int index, int sum, List list){
        if(sum > target){
            //剪枝
            return ;
        }else if(sum == target){
            ret.add(new ArrayList(list));
            return ;
        }else{
            for(int i=index ; i

你可能感兴趣的:(LeetCode题解)