【回溯】Leetcode 78. 子集【中等】

子集

给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的子集(幂集)。

解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。

示例1:
输入 :nums = [1,2,3]
输出:[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]

解题思路

  • 1、使用回溯算法来生成所有可能的子集。
  • 2、对于每个位置,都有两种选择:选择当前数字或者不选择当前数字。
  • 3、使用回溯算法来探索所有可能的选择。

Java实现

java 复制代码
public class Subsets {
    public List<List<Integer>> subsets(int[] nums) {
        List<List<Integer>> result = new ArrayList<>();
        backtrack(nums, 0, new ArrayList<>(), result);
        return result;
    }

    private void backtrack(int[] nums, int index, List<Integer> subset, List<List<Integer>> result) {
        // 将当前子集直接加入结果列表
        result.add(new ArrayList<>(subset));

        // 从当前位置开始遍历数组
        for (int i = index; i < nums.length; i++) {
            subset.add(nums[i]); // 将当前元素加入子集
            // 递归调用,更新当前位置,index+1 下一次回溯跳过当前位置
            backtrack(nums, i + 1, subset, result);
            subset.remove(subset.size() - 1); // 回溯,移除最后一个元素
        }
    }

    public static void main(String[] args) {
        Subsets solution = new Subsets();
        int[] nums = {1, 2, 3};
        List<List<Integer>> subsets = solution.subsets(nums);
        System.out.println("All subsets:");
        for (List<Integer> subset : subsets) {
            System.out.println(subset);
        }
    }
}

时间空间复杂度

  • 时间复杂度:O(2^N),其中N是数组nums的长度。因为对于每个元素,都有两种选择:选择或不选择,所以总共有2^N种子集。

  • 空间复杂度:O(2^N),存储所有可能的子集。

相关推荐
网易独家音乐人Mike Zhou3 小时前
【卡尔曼滤波】数据预测Prediction观测器的理论推导及应用 C语言、Python实现(Kalman Filter)
c语言·python·单片机·物联网·算法·嵌入式·iot
搬砖的小码农_Sky6 小时前
C语言:数组
c语言·数据结构
Swift社区7 小时前
LeetCode - #139 单词拆分
算法·leetcode·职场和发展
Kent_J_Truman7 小时前
greater<>() 、less<>()及运算符 < 重载在排序和堆中的使用
算法
先鱼鲨生7 小时前
数据结构——栈、队列
数据结构
一念之坤7 小时前
零基础学Python之数据结构 -- 01篇
数据结构·python
IT 青年8 小时前
数据结构 (1)基本概念和术语
数据结构·算法
熬夜学编程的小王8 小时前
【初阶数据结构篇】双向链表的实现(赋源码)
数据结构·c++·链表·双向链表
Dong雨8 小时前
力扣hot100-->栈/单调栈
算法·leetcode·职场和发展
SoraLuna8 小时前
「Mac玩转仓颉内测版24」基础篇4 - 浮点类型详解
开发语言·算法·macos·cangjie