LeetCode【78. 子集】

78. 子集

中等

2.2K

相关企业

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

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

示例 1:

复制代码
输入:nums = [1,2,3]
输出:[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]

示例 2:

复制代码
输入:nums = [0]
输出:[[],[0]]

提示:

  • 1 <= nums.length <= 10
  • -10 <= nums[i] <= 10
  • nums 中的所有元素 互不相同

我想了老半天 我们使用递归来生成整数数组的所有可能子集

java 复制代码
import java.util.ArrayList;
import java.util.List;

public class Solution {
    public List<List<Integer>> subsets(int[] nums) {
        List<List<Integer>> result = new ArrayList<>();
        generateSubsets(nums, 0, new ArrayList<>(), result);
        return result;
    }

    private void generateSubsets(int[] nums, int index, List<Integer> currentSubset, List<List<Integer>> result) {
        result.add(new ArrayList<>(currentSubset)); // 添加当前子集到结果集

        for (int i = index; i < nums.length; i++) {
            currentSubset.add(nums[i]); // 添加当前元素到当前子集
            generateSubsets(nums, i + 1, currentSubset, result); // 递归生成下一个子集
            currentSubset.remove(currentSubset.size() - 1); // 移除最后一个元素,回溯
        }
    }

    public static void main(String[] args) {
        Solution solution = new Solution();
        int[] nums1 = {1, 2, 3};
        System.out.println(solution.subsets(nums1));

        int[] nums2 = {0};
        System.out.println(solution.subsets(nums2));
    }
}

我们用程序定义了一个subsets方法,它通过递归调用generateSubsets方法来生成所有可能的子集。generateSubsets方法递归地构建子集,并在每次构建后将其添加到结果列表中。然后,它移除最后一个元素以进行回溯,继续生成下一个子集。

最后,subsets方法返回结果列表包含所有可能的子集。

相关推荐
OBiO20132 小时前
Cell | 突破AAV载体容量限制!路中华/姜玉武/刘太安团队开发AAVLINK系统实现大基因递送
笔记
Yzzz-F2 小时前
Problem - 2205D - Codeforces
算法
智者知已应修善业2 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn2 小时前
Java Set集合相关知识点
java·开发语言·算法
sakiko_3 小时前
UIKit学习笔记5-使用UITableView制作聊天页面
笔记·学习·swift·uikit
生成论实验室3 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星3 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
Alice-YUE4 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
JiNan.YouQuan.Soft4 小时前
FreeCAD源码分析:微内核架构
其他
科研前沿4 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算