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;
    }
};
相关推荐
superior tigre8 天前
78 子集
算法·leetcode·深度优先·回溯
Irene19918 天前
(课堂笔记)SQL 高级查询技巧:行列转换、重复数据、递归查询、连续登录
递归·去重·连续登录
旖-旎13 天前
深搜(二叉树的所有路径)(6)
c++·算法·leetcode·深度优先·递归
khalil102014 天前
代码随想录算法训练营Day-31贪心算法 | 56. 合并区间、738. 单调递增的数字、968. 监控二叉树
数据结构·c++·算法·leetcode·贪心算法·二叉树·递归
kronos.荒15 天前
非递减序列(python)
python·回溯
旖-旎15 天前
深搜(二叉树剪枝)(3)
数据结构·c++·算法·力扣·剪枝·递归
kronos.荒17 天前
回溯(python)
python·回溯
旖-旎17 天前
递归(快速幂)(5)
c++·算法·力扣·递归
旖-旎19 天前
递归(汉诺塔问题)(1)
c++·学习·算法·leetcode·深度优先·递归
kronos.荒19 天前
N皇后问题(python)
python·回溯