当前位置: 首页 > news >正文

LeetCode hot 100—子集

题目

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

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

示例

示例 1:

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

示例 2:

输入:nums = [0]
输出:[[],[0]]

分析

要找出一个整数数组 nums 的所有可能子集(幂集),可以使用回溯算法。回溯算法是一种通过尝试所有可能的组合来解决问题的算法,在这个问题中,我们可以通过递归的方式来生成所有可能的子集。

回溯

算法思路

初始化结果集:创建一个二维向量 result 用于存储所有的子集,初始时包含一个空子集。

回溯函数:定义一个回溯函数 backtrack,该函数接收当前子集、当前处理的元素索引和原数组作为参数。

  • 终止条件:当处理完所有元素时,将当前子集加入结果集。
  • 选择:对于当前元素,有两种选择:选择该元素加入当前子集,或者不选择该元素。
  • 递归:分别进行选择和不选择的递归调用。
  • 回溯:在递归调用返回后,撤销选择,以便尝试其他组合。

调用回溯函数:从索引 0 开始调用回溯函数。

返回结果集:返回存储所有子集的结果集。

时间复杂度:O(2^{n}),n 是数组的长度

空间复杂度:O(n)

class Solution {
private:
    // 回溯函数
    void backtrack(std::vector<int>& nums, int start, std::vector<int>& current, std::vector<std::vector<int>>& result) {
        // 将当前子集加入结果集
        result.push_back(current);
        // 遍历剩余元素
        for (int i = start; i < nums.size(); ++i) {
            // 选择当前元素
            current.push_back(nums[i]);
            // 递归调用,处理下一个元素
            backtrack(nums, i + 1, current, result);
            // 回溯,撤销选择
            current.pop_back();
        }
    }
public:
    std::vector<std::vector<int>> subsets(std::vector<int>& nums) {
        std::vector<std::vector<int>> result;
        std::vector<int> current;
        // 调用回溯函数
        backtrack(nums, 0, current, result);
        return result;
    }
};    

相关文章:

  • TCP专题
  • C#高级语法:Linq中使用SelectMany解决列表子项提取、双重for循环的问题
  • 06软件测试需求分析案例-添加用户
  • NLP高频面试题(四十)——什么是 BitFit?
  • Excel 插件推荐:提升Excel能力的效率神器!
  • 基于YOLOv8的机场跑道异物检测识别系统:提升航空安全的新一代解决方案(主页有源码)
  • 使用Python从零实现一个端到端多模态 Transformer大模型
  • 医院访客登记如何做才能更高效?
  • 从零开始构建智能聊天机器人:Rasa与ChatGPT API实战教程
  • 世界复合医学杂志世界复合医学杂志社世界复合医学编辑部2024年第11期目录
  • Java-servlet(完结篇)过滤器乱码解决与监听器
  • 什么是微前端?有什么好处?有哪一些方案?
  • 架构师面试(二十八):业务建模
  • 实操(环境变量)Linux
  • SAP-ABAP:SAP的Open SQL和Native SQL详细对比
  • Linux 查看 Java 项目的进程和服务名
  • java基础多态------面试八股文
  • 质检LIMS系统在半导体制造行业的应用 半导体质量革命的现状
  • 金融行业网络安全加固方案
  • 利用DeepFlow解决APISIX故障诊断中的方向偏差问题
  • 许昌哪个网站做苗木/排名公式
  • 催眠美女做仆人网站/seo索引擎优化
  • 网站建设 增值税发票/东莞网站建设推广公司
  • 知乐商城是什么网站/外链推广是什么意思
  • 设计运动品牌网站/seo优化公司哪家好
  • 邢台专业做网站费用/网站安全检测平台