力扣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();
        }
    }
};
相关推荐
NAGNIP8 小时前
万字长文!回归模型最全讲解!
算法·面试
知乎的哥廷根数学学派9 小时前
面向可信机械故障诊断的自适应置信度惩罚深度校准算法(Pytorch)
人工智能·pytorch·python·深度学习·算法·机器学习·矩阵
666HZ66610 小时前
数据结构2.0 线性表
c语言·数据结构·算法
西伯利亚狼_J202011 小时前
260109introduceEN
职场和发展
实心儿儿11 小时前
Linux —— 基础开发工具5
linux·运维·算法
charlie11451419112 小时前
嵌入式的现代C++教程——constexpr与设计技巧
开发语言·c++·笔记·单片机·学习·算法·嵌入式
清木铎13 小时前
leetcode_day4_筑基期_《绝境求生》
算法
清木铎13 小时前
leetcode_day10_筑基期_《绝境求生》
算法
j_jiajia13 小时前
(一)人工智能算法之监督学习——KNN
人工智能·学习·算法
源代码•宸13 小时前
Golang语法进阶(协程池、反射)
开发语言·经验分享·后端·算法·golang·反射·协程池