40.组合总和 II

原题链接:40.组合总和 II

思路:

太抽象了 建议看题解
代码随想录该题题解

全代码:

cpp 复制代码
class Solution {
public:
    vector<vector<int>>result;
    vector<int> path;
    bool picking = false;
    void backtracking(vector<int>& candidates, int target,int sum, int startIndex,vector<bool>& used){
        if(sum == target){
            result.push_back(path); return;
        } 

        for(int i = startIndex; i < candidates.size() && sum + candidates[i] <= target; i++)
        {
            if(i > 0 && candidates[i] == candidates[i - 1] && used[i - 1] == false) 
            {
                continue;
            }
            sum += candidates[i];
            path.push_back(candidates[i]);
            used[i] = true;
            backtracking(candidates,target,sum,i + 1,used);
            used[i] = false;
            sum -= candidates[i];
            path.pop_back();

        }
    }
    vector<vector<int>> combinationSum2(vector<int>& candidates, int target) {
         vector<bool> used(candidates.size(), false);
         sort(candidates.begin(), candidates.end());
        backtracking(candidates,target,0,0,used);
        return result;
    }
};
相关推荐
山顶夕景3 天前
【Leetcode152】分割回文串(回溯 | 递归)
算法·深度优先·回溯
朱皮皮呀14 天前
数据结构-二叉树
数据结构·二叉树·递归
Mysticbinary23 天前
汉诺塔和递归
递归·汉诺塔
Mysticbinary24 天前
以Top-Down思维去解决问题——递归
递归·top-down
志远199725 天前
算法笔试-编程练习-H-02-24
算法·模拟·回溯·大厂·最大团
markingyi25 天前
趣味算法------试用 6 和 9 组成的最大数字
c语言·数据结构·算法·递归
markingyi1 个月前
趣味算法------猴子吃桃(循环,递归双重解法)
c语言·数据结构·算法·递归·循环
听风客11 个月前
机器人走路问题优化解法
java·算法·记忆化搜索·递归
听风客11 个月前
机器人走路的问题
java·算法·递归
Trouvaille ~1 个月前
【C语言篇】递归详细介绍(基础概念习题及汉诺塔等进阶问题)
c语言·算法·递归·迭代·汉诺塔·青蛙跳台阶·数学推导