回溯-子集

78.子集

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

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

输入 :整型数组
输出 :二元列表
思路:利用二进制,(比如说数组长度为3)000、001、010、011、100、101、110、111刚好可以遍历所有情况

java 复制代码
class Solution {
    List<List<Integer>> result = new ArrayList<>();
    List<Integer> tempList = new ArrayList<>();
    public List<List<Integer>> subsets(int[] nums) {
        int n = nums.length;
        for(int i = 0; i < (1 << n); i++){
            tempList.clear();
            for(int j = 0; j < n; j++){
                if((i & (1 << j)) != 0){
                    tempList.add(nums[j]);
                }
            }
            result.add(new ArrayList<>(tempList));
        }
        return result;
    }
}
相关推荐
17(无规则自律)10 小时前
DFS连通域统计:岛屿数量问题及其变形
c++·算法·深度优先
0xDevNull10 小时前
JDK 25 新特性概览与实战教程
java·开发语言·后端
Yiyi_Coding10 小时前
BUG列表:如何定位线上 OOM ?
java·linux·bug
gelald10 小时前
Spring - 循环依赖
java·后端·spring
凤山老林11 小时前
Java 开发者零成本构建 RAG 知识库:Spring AI Alibaba + Ollama 搭建本地 RAG 知识库
java·人工智能·知识库·rag·spring ai
笨笨饿11 小时前
34_数据结构_栈
c语言·开发语言·数据结构·人工智能·嵌入式硬件·算法
爱码驱动11 小时前
文件操作和IO
java·开发语言·io·文件操作
坊钰11 小时前
Java 反射机制
java·开发语言
明灯伴古佛11 小时前
面试:为什么synchronized是一个悲观锁
java·面试·职场和发展
im_AMBER11 小时前
Leetcode 152 被围绕的区域 | 岛屿数量
数据结构·算法·leetcode·深度优先·广度优先·图搜索算法