leetcode78-子集

leetcode 78

思路

本题主要考的是回溯

result用来存储结果值,path表示每层遍历存放的值,每次递归的时候path中的结果都是结果值,所以每次递归的时候需要先把path中的内容存入result中,当startIndex === nums.length时,说明已经遍历完所有元素则结束递归

下面图中是所有的过程,以nums = [1,2,3]为例,图中pop()就是回溯的过程

实现

js 复制代码
var subsets = function(nums) {
    let result = [],path = [];
    const backtracking = (nums,startIndex)=>{
        result.push([...path])
        if(nums.length === startIndex) return;
        for(let i = startIndex;i < nums.length;i++){
            path.push(nums[i])
            backtracking(nums,i+1)
            path.pop(); // 回溯
        }
    }
    backtracking(nums,0)
    return result;
};
相关推荐
m0_7066532313 小时前
模板编译期排序算法
开发语言·c++·算法
历程里程碑13 小时前
Linxu14 进程一
linux·c语言·开发语言·数据结构·c++·笔记·算法
木井巳13 小时前
【递归算法】验证二叉搜索树
java·算法·leetcode·深度优先·剪枝
m0_5613596713 小时前
嵌入式C++加密库
开发语言·c++·算法
近津薪荼13 小时前
优选算法——双指针专题7(单调性)
c++·学习·算法
2601_9498333913 小时前
flutter_for_openharmony口腔护理app实战+意见反馈实现
android·javascript·flutter
j4455661114 小时前
C++中的职责链模式实战
开发语言·c++·算法
m0_6860416114 小时前
实时数据流处理
开发语言·c++·算法
波波侠814 小时前
代码随想录算法训练营打卡第31天|56. 合并区间、738.单调递增的数字
算法
Snow_day.14 小时前
有关线段树应用(1)
数据结构·算法·贪心算法·动态规划·图论