78 子集

子集

    • [题解1 回溯](#题解1 回溯)
    • [题解2 迭代(mask思想)](#题解2 迭代(mask思想))

给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的子集(幂集)。

解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。

示例 1:

输入:nums = [1,2,3]

输出:[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]

示例 2:

输入:nums = [0]

输出:[[],[0]]

提示:

  • 1 <= nums.length <= 10
  • -10 <= nums[i] <= 10
  • nums 中的所有元素互不相同

题解1 回溯

cpp 复制代码
class Solution {
    vector<vector<int>> ret;
    deque<int> tmp;
public:
    void backtrace(vector<int>& nums, int len, int idx){
        if(len > nums.size()) return;
        if(tmp.size() == len){
            ret.push_back(vector<int>(tmp.begin(), tmp.end()));
            // idx 此时还没用过
            backtrace(nums, len+1, idx);
            return;
        }
        for(int i = idx; i < nums.size(); i++){
            tmp.push_back(nums[i]);
            backtrace(nums, len, i+1);
            tmp.pop_back();
        }
    }
    vector<vector<int>> subsets(vector<int>& nums) {
        backtrace(nums, 0, 0);
        return ret;
    }
};

模板

cpp 复制代码
class Solution {
    vector<vector<int>> ret;
    vector<int> tmp;
public:
    void backtrace(vector<int>& nums, int idx){
        if(idx == nums.size()){
            ret.push_back(tmp);
            return;
        }
        tmp.push_back(nums[idx]);
        // 选
        backtrace(nums, idx+1);
        tmp.pop_back();
        // 不选
        backtrace(nums, idx+1);

    }
    vector<vector<int>> subsets(vector<int>& nums) {
        backtrace(nums, 0);
        return ret;
    }
};

题解2 迭代(mask思想)

cpp 复制代码
class Solution {
public:
    vector<vector<int>> subsets(vector<int>& nums) {
        vector<vector<int>> ret;
        vector<int> tmp;
        int s = nums.size();
        // 每个子集对应一个长度为s的01序列,第i位表示nums[i]是否在子集中
        // mask 的值代表tmp当前有多少个元素,以及nums哪几个元素在tmp里
        for(int mask = 0; mask < 1 << s; mask ++){
            tmp.clear();

            for(int i = 0; i < s; i++)
            // 根据mask的值把元素放到tmp里
                if(mask & (1<<i)) 
                    tmp.push_back(nums[i]);
            
            ret.push_back(tmp);
        }
        return ret;
    }
};
相关推荐
axxy20001 小时前
leetcode之hot100---24两两交换链表中的节点(C++)
c++·leetcode·链表
chenziang11 小时前
leetcode hot100 环形链表2
算法·leetcode·链表
Captain823Jack2 小时前
nlp新词发现——浅析 TF·IDF
人工智能·python·深度学习·神经网络·算法·自然语言处理
Captain823Jack3 小时前
w04_nlp大模型训练·中文分词
人工智能·python·深度学习·神经网络·算法·自然语言处理·中文分词
Aileen_0v04 小时前
【AI驱动的数据结构:包装类的艺术与科学】
linux·数据结构·人工智能·笔记·网络协议·tcp/ip·whisper
是小胡嘛4 小时前
数据结构之旅:红黑树如何驱动 Set 和 Map
数据结构·算法
m0_748255024 小时前
前端常用算法集合
前端·算法
呆呆的猫4 小时前
【LeetCode】227、基本计算器 II
算法·leetcode·职场和发展
Tisfy4 小时前
LeetCode 1705.吃苹果的最大数目:贪心(优先队列) - 清晰题解
算法·leetcode·优先队列·贪心·
余额不足121384 小时前
C语言基础十六:枚举、c语言中文件的读写操作
linux·c语言·算法