刷题记录(LeetCode 78 子集)

给你一个整数数组 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 中的所有元素 互不相同

关键词:回溯

思路:感觉比全排列还简单,只要一直往数组里加数字就行了,然后每次递归调用dfs的时候都插进去,只要保证for循环从上一次递归的下一个位置开始遍历就可以了。

题解如下:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> subsets(vector<int>& nums) {
        vector<vector<int>> res;
        vector<int> tmp;
        dfs(res, tmp, nums, 0);
        return res;
    }

    void dfs(vector<vector<int>>& res, vector<int>& tmp, vector<int>& nums, int index) {
        res.push_back(tmp);
        for(int i = index; i < nums.size(); i++) {
            tmp.push_back(nums[i]);
            dfs(res, tmp, nums, i + 1);
            tmp.pop_back();
        }
    }
};
相关推荐
不要秃头的小孩几秒前
力扣刷题——77. 组合
数据结构·python·算法·leetcode
2401_857918292 分钟前
实时数据处理中的C++应用
开发语言·c++·算法
2401_884563243 分钟前
C++中的装饰器模式实战
开发语言·c++·算法
MicroTech20257 分钟前
微算法科技(NASDAQ :MLGO)抗量子区块链技术:筑牢量子时代的数字安全防线
科技·算法·区块链
Ivanqhz9 分钟前
图着色寄存器分配算法(Graph Coloring)
开发语言·javascript·python·算法·蓝桥杯·rust
Elsa️74611 分钟前
洛谷p5718 复习下快速排序和堆排序
数据结构·算法·排序算法
Frostnova丶14 分钟前
LeetCode 3567.子矩阵的最小绝对差
算法·leetcode·矩阵
夏日听雨眠15 分钟前
文件学习9
数据结构·学习·算法
华农DrLai16 分钟前
什么是自动Prompt优化?为什么需要算法来寻找最佳提示词?
人工智能·算法·llm·nlp·prompt·llama
黎阳之光16 分钟前
十五五智赋新程 黎阳之光以AI硬核技术筑造产业数智底座
大数据·人工智能·算法·安全·数字孪生