力扣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();
        }
    }
};
相关推荐
TDengine (老段)2 分钟前
TDengine 压缩编码机制 — 双层压缩架构与类型特化算法
大数据·数据库·物联网·算法·时序数据库·tdengine·涛思数据
妄想出头的工业炼药师1 小时前
LVIO鲁棒
算法·开源
aini_lovee1 小时前
MATLAB 图像修复 — 偏微分方程方法
算法
Purple Coder1 小时前
MgB2论文草稿1
职场和发展
Cthy_hy1 小时前
Python算法竞赛:排列组合核心用法
开发语言·python·算法
大圣编程2 小时前
面向对象深度理解
java·开发语言·算法
爱喝水的鱼丶2 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第四篇:SAP 报表异常处理机制:数据校验与消息提示规范落地
开发语言·数据库·学习·算法·sap·abap
wabs6662 小时前
关于贪心算法【划分字母区间】的问题总结(C++语法)
算法·贪心算法
啦啦啦啦啦zzzz3 小时前
数据结构:二叉树的线索化
数据结构·算法
2401_872418783 小时前
算法入门:并查集(Disjoint Set / Union-Find):连通性问题的利器
算法