力扣题/回溯/子集

子集

力扣原题

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

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

示例 1:

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

示例 2:

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

/**
 * @param {number[]} nums
 * @return {number[][]}
 */
var subsets = function(nums) {
    const res = []
    function dfs(idx = -1, arr = []) {

        if(idx > -1) {
            arr.push(nums[idx])
        }

        res.push(arr)

        for(let i = idx + 1; i < nums.length; i++) {
            dfs(i, [...arr])
        }
        
    }
    
    dfs()

    return res
};

解题思路

使用深度遍历,因为需要返回所有子集,则不能重复,所以在深度遍历中,每一层 的for循环,都不循环前面已经遍历过的数即可,即for循环中的let i = idx + 1;
nums = [1,2,3]举例:

  1. 开始dfs(),第0层, 结果为 []
  2. 第0层for循环 i = 0,dfs(0, []),进入第1层, 结果为[1]
  3. 第1层for循环 i = 1,dfs(1, [1]),进入第2层, 结果为[1, 2]
  4. 第2层for循环 i = 2,dfs(2, [1, 2]), 进入第3层,结果为[1, 2, 3]
  5. 第3层for循环 i = 3循环结束,退回第2层for循环 i = 3循环结束,退回第1层
  6. 第1层 for循环 i = 2,dfs(2, [1]),进入第2层,结果为[1, 3]
  7. 第2层for循环 i = 3循环结束,退回第1层for循环 i = 3循环结束,退回第0层
  8. 第0层for循环 i = 1,dfs(1, []),进入第1层, 结果为[2]
  9. 第1层for循环 i = 2,dfs(2, [2]), 进入第2层,结果为[2, 3]
  10. 第2层for循环 i = 3结束循环,退回第1层for循环 i = 3循环结束,退回第0层
  11. 第0层for循环 i = 2,dfs(2, []),进入第1层, 结果为[3]
  12. 第1层for循环 i = 3循环结束
  • 最终输出结果为:[[],[1],[1,2],[1,2,3],[1,3],[2],[2,3],[3]]
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

温温温B

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值