【回溯】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(2N),其中N是数组nums的长度。因为对于每个元素,都有两种选择:选择或不选择,所以总共有2N种子集。

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

相关推荐
古城小栈2 小时前
为啥说:训练用BF16,推理用FP16
人工智能·算法·机器学习
KaMeidebaby2 小时前
卡梅德生物技术快报|蛋白 N 端测序在重组贻贝融合蛋白表征中的应用,解决原核表达序列偏移工艺难题
前端·人工智能·物联网·算法·百度
Turbo正则3 小时前
群论在AI中的应用概述
人工智能·算法·抽象代数
ysa0510303 小时前
【并查集】判环
c++·笔记·算法
Jerry3 小时前
KeetCode 44. 开发商购买土地
算法
Jerry4 小时前
KeetCode 58. 区间和
算法
Jerry5 小时前
LeetCode 209. 长度最小的子数组
算法
彦为君5 小时前
算法思维与经典智力题
java·前端·redis·算法
智能优化与强化学习5 小时前
Gym(Gymnasium)仿真环境详解(二):环境简介、入门算法、调参要点、核心挑战
算法·强化学习·gym·零基础入门·算法评估
mxwin5 小时前
Unity Shader exp 函数的算法与渲染应用
算法·unity·游戏引擎·shader