【算法三十二】

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)

相关推荐
Mr_Xuhhh2 小时前
LeetCode 热题 100 刷题笔记:高频面试题详解(215 & 347)
算法·leetcode·排序算法
mmz12072 小时前
贪心算法3(c++)
c++·算法·贪心算法
j_xxx404_2 小时前
蓝桥杯基础--排序模板合集II(快速,归并,桶排序)
数据结构·c++·算法·蓝桥杯·排序算法
月落归舟2 小时前
排序算法---(四)
算法·排序算法
童话ing2 小时前
【LeetCode】239.滑动窗口最大值
数据结构·算法·leetcode·golang
计算机安禾2 小时前
【数据结构与算法】第13篇:栈(三):中缀表达式转后缀表达式及计算
c语言·开发语言·数据结构·c++·算法·链表
章鱼丸-2 小时前
DAY40 训练与测试规范写法
人工智能·算法·机器学习
代码飞天3 小时前
算法与数据结构之又臭又长的表
数据结构·算法
A923A3 小时前
【洛谷刷题 | 第七天】
算法·模拟·洛谷