【算法三十二】

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)

相关推荐
随意起个昵称1 小时前
区间dp-基础题目1(石子合并)
算法·动态规划
吞下星星的少年·-·1 小时前
线段树模板
算法
段一凡-华北理工大学2 小时前
2026 高炉炼铁智能化技术全景与演进路径~系列文章11:演进路径与行业未来
大数据·网络·人工智能·算法·工业智能体·高炉炼铁智能化
叶小鸡2 小时前
小鸡玩算法-力扣HOT100-多维动态规划
算法·leetcode·动态规划
星马梦缘2 小时前
aaaaa
数据结构·c++·算法
菜菜的顾清寒3 小时前
力扣HOT100(42)链表-随机链表的复制
算法·leetcode·链表
lqqjuly3 小时前
模型剪枝与稀疏化:理论、算法与可运行实现
人工智能·算法·剪枝
逻辑君4 小时前
Foresight研究报告【20260011】
人工智能·线性代数·算法·矩阵
珊瑚里的鱼4 小时前
【动态规划】不同路径Ⅱ
算法·动态规划
适应规律4 小时前
【无标题】
人工智能·python·算法