【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<List<Integer>> ret = new ArrayList<>();
    public List<List<Integer>> combinationSum(int[] candidates, int target) {
        Arrays.sort(candidates);
        List<Integer> list = new ArrayList<>();
        getNum(candidates, target,0, 0, list);
        return ret;
    }
    //index记录当前位置,选取下一个元素时只能选取当前元素及之后的任一元素
    void getNum(int[] c, int target ,int index, int sum, List<Integer> list){
        if(sum > target){
            //剪枝
            return ;
        }else if(sum == target){
            ret.add(new ArrayList(list));
            return ;
        }else{
            for(int i=index ; i<c.length ; i++){
                list.add(c[i]);
                getNum(c, target, i, sum+c[i], list);
                list.remove(list.size()-1);
            }
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值