回溯-子集

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;
    }
}
相关推荐
java1234_小锋6 分钟前
Spring里AutoWired与Resource区别?
java·后端·spring
风象南10 分钟前
Spring Boot 定时任务多实例互斥执行
java·spring boot·后端
崎岖Qiu10 分钟前
【深度剖析】:结合 Spring Bean 的生命周期理解 @PostConstruct 的原理
java·笔记·后端·spring·javaee
毕设源码-郭学长14 分钟前
【开题答辩全过程】以 基于Springboot旅游景点管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
是三好19 分钟前
JUC并发编程
java·开发语言
睡一觉就好了。19 分钟前
直接选择排序
数据结构·算法·排序算法
哈哈不让取名字24 分钟前
分布式日志系统实现
开发语言·c++·算法
芬加达26 分钟前
leetcode221 最大正方形
java·数据结构·算法
知无不研30 分钟前
实现一个整形栈
c语言·数据结构·c++·算法
夏鹏今天学习了吗33 分钟前
【LeetCode热题100(98/100)】子集
算法·leetcode·深度优先