Leetcode 39-Combination Sum

题目:

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

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

说明:

  • 所有数字(包括 target)都是正整数。
  • 解集不能包含重复的组合。 


思路:

    这题比较烦,最近事比较多,所以就一直卡着没动过。思路倒是对的,用递归,然后用一个int标记当前遍历的位置,然后一层层递归。这题也是我接触的第一个递归题,类似八皇后,有空可以多回味一下,我的递归水平比较差。

    递归的原理是每提取一个数组的值,然后以这个值为基点,重新调用方法,只不过target变为target-这个数组的值。每一次return的时候,表示当前数已经用完,不再调用,应返回上一层再向右遍历。不多说,贴上代码。

    代码如下:

class Solution {
    public List<List<Integer>> combinationSum(int[] candidates, int target) {
        List<List<Integer>> result =new ArrayList<>();
        
        if(candidates.length<1||candidates == null ){
            
            return result;
        }
        Arrays.sort(candidates);

        backresult(candidates,target,result,new ArrayList<Integer>(),0);
        
        return result;
    }
    
    public void backresult(int[] nums, int target,List<List<Integer>> result,ArrayList<Integer>list,int start)
    {
        if(target<0)
        {
            return;//当前选得太大。退出该方法的意义在于:删除该球,上一级求开始向右寻找。
        }
        
        if(target==0)
        {
            result.add(list);
            return;
            
        }    
        
        for(int i=start;i<nums.length&&target>=nums[i];i++){
            list.add(nums[i]);
            backresult(nums,target-nums[i],result,new ArrayList<Integer>(list),i);
            list.remove(list.size()-1);
            
        }
        
        
    }
}

    说明:

   1.


if(target<0)

    这个情况说明取了某个数组的值之后,当前所取数之和已经大于target,于是return,停止调用这个数,并将这个数删掉。

    2.

if(target==0)

    这个情况说明取了某个数之和,刚好得到,于是加入结果中,停止调用这个数,并删掉。

    3.

for(int i=start;i<nums.length&&target>=nums[i];i++){
            list.add(nums[i]);
            backresult(nums,target-nums[i],result,new ArrayList<Integer>(list),i);
            list.remove(list.size()-1);

    这一段是指,每一层的数都要向右遍历,并且不能遍历在自己之前的数,这样会造成重复,调用结束之后,删数返回,重新回到上一轮开始。值得一提的是有点不太理解new ArrayList<Integer>(list)为什么不能直接传list而是要new一个新的然后把list传进去。以后有空再编辑~


    结果如下:



    总结:结果还可以,不过每次要new一个list,感觉有点浪费。第一个递归题,值得多回味。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值