LeetCode(python)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 中的所有元素 互不相同

思路

每个数字都有两种选择(选/不选)用递归解决:

递归的三要素:

1.递归函数要做什么

(1)对每个数字进行决策,选还是不选

(2)把决策后的子集收集到最终的结果中

2.终止条件------当所有数字都决策过了,就存入此次递归的结果

3.单层逻辑

处理当前第index个元素时,有两种选择:

(1)选当前元素->加入临时子集->继续决策下一个元素

(2)不选当前元素->把它从临时子集中剔除->继续决策下一个元素(回溯)

代码

注意!res.append(temp:),不能写成res.append(temp),这样存的是temp的引用,后续会随着递归而改变

python 复制代码
class Solution:
    def subsets(self, nums: List[int]) -> List[List[int]]:
        res = []    # 存结果
        temp = []   # 存临时子集

        def dfs(index):
            if index == len(nums):        # 终止条件
                res.append(temp[:])       # 注意!一定要加:,不然存的就是temp的引用,会随着递归时temp的变换而变换,导致最后全为空
                return
            temp.append(nums[index])      # 选当前元素
            dfs(index + 1)                # 继续决策下一个

            temp.pop()                    # 不选
            dfs(index + 1)                # 继续决策下一个
        
        dfs(0)                            # 从第一个元素开始处理
        return res
相关推荐
Cloud_Shy618几秒前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 36 - 39)
开发语言·人工智能·笔记·python
阿正的梦工坊几秒前
【Rust】11-Rust 所有权模型的编译期推理机制
开发语言·算法·rust
zmzb01031 分钟前
Python课后习题训练记录Day128
开发语言·python
AIFQuant2 分钟前
全球行情自动更新、多品种展示、性能优化实战指南
python·性能优化·金融·node.js·restful
callJJ3 分钟前
Java 线程池使用指南:基于 Spring Boot 3.x + JDK 17 的入门与实践
java·开发语言·spring boot·线程池·多线程编程
爱喝水的鱼丶4 分钟前
SAP-ABAP:SAP多表连接视图实战:内连接/外连接配置逻辑与性能优化技巧
运维·开发语言·学习·性能优化·sap·abap
风筝在晴天搁浅4 分钟前
LeetCode CodeTop 88.合并两个有序数组
算法·leetcode·职场和发展
蜂蜜黄油呀土豆5 分钟前
ReWOO 与 Plan-and-Execute:解耦的规划
python·ai·大模型
GuWen_yue5 分钟前
吃透二叉树与递归!60分钟掌握树结构核心+解题思路
javascript·算法
星恒随风5 分钟前
C++ 类和对象入门(六):友元、内部类、匿名对象和编译器优化
开发语言·c++·笔记·学习·状态模式