欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 幼教 > 2.25力扣-回溯组合总和

2.25力扣-回溯组合总和

2025/2/26 22:17:29 来源:https://blog.csdn.net/leeyayai_xixihah/article/details/145858826  浏览:    关键词:2.25力扣-回溯组合总和

39. 组合总和 - 力扣(LeetCode)

一:Java

class Solution {List<List<Integer>> ans=new LinkedList<>();List<Integer> temp=new LinkedList<>();int sum=0;public List<List<Integer>> combinationSum(int[] candidates, int target) {df(candidates, target, 0);return ans;}public void df(int[] candidates, int target,int start){if(sum>target) return ;if(sum==target){ans.add(new LinkedList<>(temp));return ;}for (int i = start; i < candidates.length; i++) {temp.add(candidates[i]);sum+=candidates[i];df(candidates, target, i);sum-=candidates[i];temp.removeLast();}}
}

为什么删去:if(sum>target) return ; 语句,会报错  --  栈溢出

因为递归是i开始,而非i+1,如果没有这个 if(sum>target) return 语句,达不到sum==target的条件,会一直在i处累加,最后一直递归没有结束。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词