其他分享
首页 > 其他分享> > 39. 组合总和

39. 组合总和

作者:互联网

✅做题思路or感想

这里依旧是找组合,故依旧是用回溯法

而因为这里的元素是可以重复选取的,所以这里的startIndex在递归时不需要+1,或者直接干脆不用startIndex就可以了

但是为了防止[2,2,3],[2,3,2]这种重复,所以需要安排一下子集都是要递增的就好了

class Solution {
public:
    vector<int>temp;
    vector<vector<int>>result;
    //这里直接取消了startIndex,不需要再强制性的缩小取值范围了,因为单个值可以无限的取
    void dfs(vector<int>& candidates, int target) {
        if (target < 0)return;	//容易想到且有效的剪枝
        if (target == 0) {	//递归中止条件
            result.push_back(temp);
            return;
        }
        //处理数据
        for (int i = 0; i < candidates.size(); i++) {
            //这里if是维持子集是单调递增的!
            if (temp.size() != 0 && temp.back() <= candidates[i] || temp.size() == 0) {
            temp.push_back(candidates[i]);
            dfs(candidates, target - candidates[i]);
            temp.pop_back();//回溯
            }
        }
    }
    vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
        dfs(candidates, target);
        return result;
    }
};

标签:39,return,target,组合,int,startIndex,candidates,result,总和
来源: https://www.cnblogs.com/doomaa/p/16086286.html