54 子集

1.题目描述

示例 1:

复制代码
输入:nums = [1,2,3]
输出:[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]

示例 2:

复制代码
输入:nums = [0]
输出:[[],[0]]

2.代码

cpp 复制代码
class Solution {
public:
    vector<vector<int>> res;
    vector<int> path;
    void backtrack(vector<int> &nums, int startindex){
        res.push_back(path);
        if(startindex >= nums.size()){
            return;
        }//递归终止条件
        for(int i = startindex;i<nums.size();i++){
            path.push_back(nums[i]);
            backtrack(nums,i+1);
            //回溯,比如当时path = {1 2 3}return到此处了,则需要回退到{1 2 }这一层继续for循环
            path.pop_back();
        }                   
    }
    vector<vector<int>> subsets(vector<int>& nums) {
        backtrack(nums,0);
        return res;
    }
};
相关推荐
近津薪荼2 小时前
递归专题5——快速幂
c++·学习·算法
小龙报2 小时前
【数据结构与算法】指针美学与链表思维:单链表核心操作全实现与深度精讲
c语言·开发语言·数据结构·c++·物联网·算法·链表
一起养小猫2 小时前
Flutter for OpenHarmony 实战:扫雷游戏算法深度解析与优化
算法·flutter·游戏
!停3 小时前
数据结构二叉树——堆
java·数据结构·算法
一匹电信狗11 小时前
【LeetCode_547_990】并查集的应用——省份数量 + 等式方程的可满足性
c++·算法·leetcode·职场和发展·stl
鱼跃鹰飞11 小时前
Leetcode会员尊享100题:270.最接近的二叉树值
数据结构·算法·leetcode
梵刹古音12 小时前
【C语言】 函数基础与定义
c语言·开发语言·算法
筵陌13 小时前
算法:模拟
算法
We་ct13 小时前
LeetCode 205. 同构字符串:解题思路+代码优化全解析
前端·算法·leetcode·typescript