【算法三十二】

78. 子集

回溯:

java 复制代码
class Solution {
    private List<List<Integer>> ans = new ArrayList<>();
    private List<Integer> path = new ArrayList<>();
    public List<List<Integer>> subsets(int[] nums) {
        // 从索引 0 开始搜索
        backtrack(nums,0);
        return ans;
    }

    private void backtrack(int[] nums,int stratIndex){
        //刚进去就加,避免漏
        ans.add(new ArrayList<>(path));
        
        //终止条件
        if(stratIndex > nums.length-1){
            return;
        }

        for(int i = stratIndex;i<nums.length;i++){
            //在起始index上累加子集,1,12,123
            path.add(nums[i]);
            //回溯,起到1,12,123的效果
            backtrack(nums,i+1);
            //回溯删除
            path.remove(path.size()-1);
        }
    }
}

时间复杂度:O(N*2^n)

空间复杂度:O(N)

相关推荐
Hello.Reader1 小时前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
绛橘色的日落(。・∀・)ノ2 小时前
机器学习之评估与偏差方差分析
算法
消失的旧时光-19432 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
AI_Ming3 小时前
从0开始学AI:层归一化,原来是这回事!
算法·ai编程
WL_Aurora3 小时前
备战蓝桥杯国赛【Day 8】
算法·蓝桥杯
智者知已应修善业3 小时前
【51单片机模拟生日蜡烛】2023-10-10
c++·经验分享·笔记·算法·51单片机
MediaTea3 小时前
Scikit-learn:从数据到结构——无监督学习的最小闭环
人工智能·学习·算法·机器学习·scikit-learn
智者知已应修善业3 小时前
【51单片机如何让LED灯从一亮到八,再从八亮到一】2023-10-13
c++·经验分享·笔记·算法·51单片机
qeen873 小时前
【数据结构】二叉树相关经典函数C语言实现
c语言·数据结构·c++·笔记·学习·算法·二叉树
良木生香4 小时前
【C++初阶】STL——List从入门到应用完全指南(1)
开发语言·数据结构·c++·程序人生·算法·蓝桥杯·学习方法