力扣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();
        }
    }
};
相关推荐
无聊的小坏坏29 分钟前
一文详解前缀和:从一维到二维的高效算法应用
数据结构·算法
泽020236 分钟前
C++之模板进阶
开发语言·c++·算法
蒙奇D索大1 小时前
【数据结构】图论最短路圣器:Floyd算法如何用双矩阵征服负权图?
数据结构·算法·矩阵·图论·图搜索算法
潘小磊1 小时前
高频面试之6Hive
大数据·hive·面试·职场和发展
白熊1882 小时前
【推荐算法】注意力机制与兴趣演化:推荐系统如何抓住用户的心?
算法·php·推荐算法
Sun_light2 小时前
LeetCode 59.「螺旋矩阵」
javascript·算法·面试
数据与人工智能律师3 小时前
当机床开始“思考”,传统“制造”到“智造”升级路上的法律暗礁
大数据·网络·算法·云计算·区块链
IC 见路不走3 小时前
LeetCode 第73题:矩阵置零
算法·leetcode·矩阵
黑听人3 小时前
【力扣 简单 C】141. 环形链表
c语言·开发语言·数据结构·算法·leetcode
谷雨不太卷4 小时前
AVL树的实现
数据结构·c++·算法