回溯-子集

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;
    }
}
相关推荐
NineData44 分钟前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
木心月转码ing2 小时前
Hot100-Day14-T33搜索旋转排序数组
算法
暮色妖娆丶4 小时前
不过是吃了几年互联网红利罢了,我高估了自己
java·后端·面试
NE_STOP4 小时前
MyBatis-参数处理与查询结果映射
java
会员源码网4 小时前
内存泄漏(如未关闭流、缓存无限增长)
算法
狂奔小菜鸡5 小时前
Day40 | Java中的ReadWriteLock读写锁
java·后端·java ee
颜酱5 小时前
从0到1实现LFU缓存:思路拆解+代码落地
javascript·后端·算法
SimonKing6 小时前
JetBrains 用户狂喜!这个 AI 插件让 IDE 原地进化成「智能编码助手」
java·后端·程序员
狂奔小菜鸡6 小时前
Day39 | Java中更灵活的锁ReentrantLock
java·后端·java ee