LeetCode40 组合总和 II

前言

题目: 40. 组合总和 II
文档: 代码随想录------组合总和 II
编程语言: C++
解题状态: 没思路...

思路

所谓去重,其实就是使用过的元素不能重复选取。在树形结构中,"使用过"在这个树形结构上是有两个维度的,一个维度是同一树枝上使用过,一个维度是同一树层上使用过。

代码

cpp 复制代码
class Solution {
private:
    vector<vector<int>> res;
    vector<int> path;
    void backtracking(vector<int>& candidates, int target, int sum, int startIndex, vector<bool> used) {
        if (sum == target) {
            res.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();
        }
    }
public:
    vector<vector<int>> combinationSum2(vector<int>& candidates, int target) {
        vector<bool> used(candidates.size(), false);
        path.clear();
        res.clear();
        sort(candidates.begin(), candidates.end());
        backtracking(candidates, target, 0, 0, used);
        return res;
    }
};
  • 时间复杂度: O ( n ∗ 2 n ) O(n*2^n) O(n∗2n)
  • 空间复杂度: O ( n ) O(n) O(n)
相关推荐
mit6.82417 小时前
[VT-Refine] Simulation | Fine-Tuning | docker/run.sh
算法
朴shu17 小时前
Delta数据结构:深入剖析高效数据同步的奥秘
javascript·算法·架构
持梦远方17 小时前
【C++日志库】启程者团队开源:轻量级高性能VoyLog日志库完全指南
开发语言·c++·visual studio
mit6.82417 小时前
博弈dp|凸包|math分类
算法
许长安17 小时前
C++中指针和引用的区别
c++·经验分享·笔记
Shinom1ya_17 小时前
算法 day 41
数据结构·算法·leetcode
hetao173383718 小时前
2025-10-30 ZYZOJ Star(斯达)模拟赛 hetao1733837的record
c++·算法
无敌最俊朗@18 小时前
C++ 值类别与移动语义详解(精简版)
java·数据结构·算法
lingran__19 小时前
算法沉淀第十一天(序列异或)
c++·算法
一匹电信狗19 小时前
【C++】红黑树详解(2w字详解)
服务器·c++·算法·leetcode·小程序·stl·visual studio