回溯-子集

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;
    }
}
相关推荐
于指尖飞舞14 小时前
java后端面试题(多线程极简)
java·开发语言
IT 行者15 小时前
GitHub Spec Kit 实战(四):读懂和干预 /speckit.plan——AI 最自由发挥的一步
java·人工智能·github·ai编程·claude
bIo7lyA8v15 小时前
算法稳定性与数据分布的内在联系研究的技术8
算法
独隅15 小时前
IntelliJ IDEA 在 Windows 上的完整安装与使用指南
java·windows·intellij-idea
Misnearch15 小时前
为什么List<int[]> ans = new ArrayList<>()能成功创建
java·object
SHARK_pssm15 小时前
【数据结构——树与堆】
c语言·数据结构·经验分享·笔记
梦想的颜色15 小时前
从零入门:Docker在Ubuntu上的安装、使用与主流镜像仓库实战(Java/Go/MySQL/PostgreSQL/MongoDB/Nginx
java·ubuntu·docker
是多巴胺不是尼古丁15 小时前
期末java复习--string
java·开发语言·python
Survivor00115 小时前
高并发系统流量治理的底层算法
java·开发语言
bIo7lyA8v15 小时前
算法可视化对教学与调试效率的影响分析的技术8
算法