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;
    }
};
相关推荐
robin_suli14 天前
穷举vs暴搜vs深搜vs回溯vs剪枝系列一>不同路径 III
算法·剪枝·深度优先遍历·回溯
robin_suli15 天前
穷举vs暴搜vs深搜vs回溯vs剪枝系列一>黄金矿工
算法·剪枝·深度优先遍历·回溯
利刃大大15 天前
【回溯+剪枝】单词搜索,你能用递归解决吗?
剪枝·深度优先遍历·回溯·递归
利刃大大17 天前
【回溯+剪枝】优美的排列 && N皇后(含剪枝优化)
算法·二叉树·剪枝·回溯·递归
robin_suli17 天前
穷举vs暴搜vs深搜vs回溯vs剪枝系列一>单词搜索
算法·剪枝·深度优先遍历·回溯·递归
xiao--xin25 天前
LeetCode100之子集(78)--Java
java·算法·leetcode·回溯
xiao--xin25 天前
LeetCode100之全排列(46)--Java
java·算法·leetcode·回溯
m0_675988231 个月前
Leetcode40: 组合总和 II
算法·leetcode·回溯·排序·python3
lisanndesu1 个月前
专题三_穷举vs暴搜vs深搜vs回溯vs剪枝_全排列
dfs·回溯
adam_life1 个月前
http://noi.openjudge.cn/——4.7算法之搜索——【169:The Buses】
算法·回溯·递归深搜·线路判断