力扣78. 子集

Problem: 78. 子集

文章目录

题目描述

思路及解法

1.定义一维数组track用于记录决策路径,二维数组res用于存储所有的子集;

2.决策阶段:从0阶段起来(0阶段决策路径中为空集),每次将当前阶段的决策路径添加到res中;为了保证元素的不重复 我们要保证原始数组nums中元素的相对顺序 ,则在利用回溯模板解题时我们每次使得循环中的索引起始位置从当前的决策阶段开始

复杂度

时间复杂度:

O ( N × 2 N ) O(N \times 2^N) O(N×2N);其中 N N N为数组nums的长度

空间复杂度:

O ( N ) O(N) O(N)

Code

C++ 复制代码
class Solution {
    //Recode the result
    vector<vector<int>> res;
    //Recode the Decision path
    vector<int> track;
public:
    /**
     *  subset
     *  
     * @param nums Universe
     * @return vector<vector<int>>
     */
    vector<vector<int>> subsets(vector<int>& nums) {
        backtrack(nums, 0);
        return res;
    }

    /**
     * Backtracking function
     * 
     * @param nums Universe
     * @param start Decision stage
     */
    void backtrack(vector<int>& nums, int start) {
        res.push_back(track);

        for (int i = start; i < nums.size(); ++i) {
            track.push_back(nums[i]);
            backtrack(nums, i + 1);
            track.pop_back();
        }
    }
};
相关推荐
To_OC3 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635078 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC9 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥10 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者11 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者11 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月14 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星15 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星15 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试