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

力扣题/回溯/子集

子集

力扣原题

给你一个整数数组 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]]

http://www.kler.cn/a/282189.html

相关文章:

  • <项目代码>YOLOv8 番茄识别<目标检测>
  • Java基础-Java中的常用类(上)
  • 英语中的副词和状语
  • AI 提示词(Prompt)入门 十:最佳实践|详细询问,提供细节!
  • Mac 电池没电关机导致时间不同步
  • 蓝桥杯备赛(持续更新)
  • java.time包时间类浅谈
  • C语言中的int argc, char *argv[]是什么?
  • 设计模式 10 外观模式
  • mysql集群从零开始搭建
  • Qt详解QUrl
  • CSS动画魔法:用@keyframes点亮你的网页
  • Python操作Excel的十大技巧
  • 算法的学习笔记—数据流中的中位数(牛客JZ41)
  • 数学建模~~~预测方法--决策树模型
  • pyautogui的一些自动化示例,附代码
  • 新手如何找到正确入行 Web3 路径?揭开职业启航新篇章
  • linux驱动 -- 输入子系统
  • 【STM32】SPI
  • HFM深入技术学习系列之五--FDMEE钻取EBS
  • 单链表——随机链表的复制
  • 开源模型应用落地-LlamaIndex学习之旅-LLMs-集成OpenAI(一)
  • 322.零钱兑换
  • HAL库:串口 不定长数据接收 + 循环收发缓冲区 + 空闲中断 收发数据
  • SpringMVC框架学习
  • 使用ftl文件导出时,多层嵌套循环