leetcode 39 组合总和

简介: leetcode 39 组合总和

组合总和

4730ef5073e04443ba141d7c6cd05f21.png

暴力回溯(无剪枝,时间复杂度高)

class Solution {
public:
    vector<vector<int>> result;
    vector<int> path;
    int sum;
    void backtracking(vector<int>& candidates, int target , int sum)
    { 
      //检测目标大于时返回
        if(sum > target) return;
        if(sum == target)
        {
          //排序后发现是新结果插入
            vector<int> tmp(path.begin(),path.end());
            sort(tmp.begin(),tmp.end());
            auto it = find(result.begin(),result.end(),tmp);
            if(it == result.end()) result.push_back(tmp);
            return;
        }
    //无任何限制回溯
        for(int i = 0 ; i < candidates.size() ;i++)
        {
            path.push_back(candidates[i]);
            backtracking(candidates,target,sum+candidates[i]);
            path.pop_back();
        }
        return;
    }
    vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
        backtracking(candidates,target,0);
        return result;
    }
};

回溯剪枝

class Solution {
public:
    vector<vector<int>> result;
    vector<int> path;
    int sum;
    void backtracking(vector<int>& candidates, int target , int sum , int indnx)
    {
        if(sum > target) return;
        if(sum == target)
        {
            result.push_back(path);
            return;
        }
      //剪枝,因为之前已经对输入进行排序,当发现加上i点的值大于目标后,后面的也都大于
        for(int i = indnx ; i < candidates.size() && sum+candidates[i] <= target ;i++)
        {
            path.push_back(candidates[i]);
            //递归的下一个指针和当前一样都是i,不是i+1 
            //因为一个数可以重复的使用,不能重复是i+1
            backtracking(candidates,target,sum+candidates[i] , i);
            path.pop_back();
        }
        return;
    }
    vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
        //对输入进行排序,方便后面循环
        sort(candidates.begin(),candidates.end());
        backtracking(candidates,target,0,0);
        return result;
    }
};

二刷

class Solution {
public:
    vector<int> path;
    vector<vector<int>> result;
    int sumNum=0;
    void dfs(vector<int>& candidates, int target,int fir)
    {
        if(sumNum > target) return;
        if(sumNum == target)
        {
            result.push_back(path);
            return;
        }
        for(int i=fir ; i<candidates.size() ; i++)
        {
            path.push_back(candidates[i]);
            sumNum += candidates[i];
            dfs(candidates,target,i);
            sumNum -= candidates[i];
            path.pop_back();
        }
    }
    vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
        dfs(candidates,target,0);
        return result;
    }
};
相关文章
|
3月前
Leetcode第40题(组合总和2)
LeetCode第40题“组合总和II”的解题方法,使用了回溯法来找出所有可能的组合,并对重复元素进行了处理。
34 0
|
3月前
【LeetCode 51】216.组合总和III
【LeetCode 51】216.组合总和III
16 1
|
3月前
【LeetCode 53】39.组合总和
【LeetCode 53】39.组合总和
42 0
|
3月前
LeetCode第39题(组合总和)
LeetCode第39题要求找出一个无重复元素整数数组中所有和为给定目标数的不同组合,可以使用回溯法解决。
56 0
|
5月前
|
算法
LeetCode第40题组合总和II
LeetCode第40题"组合总和II"的解题策略,涉及排序、去重和使用标记数组避免重复组合,通过回溯法实现递归组合。
LeetCode第40题组合总和II
|
5月前
|
算法
LeetCode第39题组合总和
LeetCode第39题"组合总和"的解题思路和技巧,采用回溯法通过递归代替多层嵌套循环,有效解决组合问题。
LeetCode第39题组合总和
|
8月前
|
Java
leetcode-40:组合总和 II
leetcode-40:组合总和 II
56 0
|
8月前
|
Java
leetcode-377:组合总和 Ⅳ
leetcode-377:组合总和 Ⅳ
46 0
|
8月前
|
Java
leetcode-216:组合总和 III
leetcode-216:组合总和 III
41 0
|
8月前
|
Java 索引
leetcode-39:组合总和
leetcode-39:组合总和
48 0

热门文章

最新文章

下一篇
开通oss服务