2.25力扣-回溯组合总和

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

一:Java

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处累加,最后一直递归没有结束。

相关推荐
熊文豪10 小时前
【华为OD】区块链文件转储系统
算法·华为od·区块链
塔中妖10 小时前
【华为OD】Linux发行版的数量
linux·算法·华为od
熊文豪10 小时前
【华为OD】阿里巴巴找黄金宝箱
算法·华为od
bestadc10 小时前
LeetCode 几道 Promises 和 Time 的题目
javascript·算法·leetcode
墨染点香10 小时前
LeetCode 刷题【71. 简化路径】
算法·leetcode·职场和发展
知彼解己10 小时前
【算法】四大基础数据结构
数据结构·算法
老一岁10 小时前
希尔排序详解
数据结构·算法·排序算法
lifallen10 小时前
KafkaStreams 计算图节点设计:ProcessorNode、SourceNode、SinkNode
java·数据结构·算法·kafka·apache
索迪迈科技10 小时前
java后端工程师进修ing(研一版‖day42)
java·开发语言·学习·算法
名誉寒冰11 小时前
LeetCode 24 两两交换链表中的节点( 迭代与递归)
算法·leetcode·链表