LeetCode-90-子集Ⅱ

题目描述:给你一个整数数组 nums ,其中可能包含重复元素,请你返回该数组所有可能的子集(幂集)。

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

题目链接:LeetCode-90-子集Ⅱ

解题思路:跟 组合总和Ⅱ相似,都需要去重操作。

注意要先对数组排序,方便去重。
代码实现:

java 复制代码
class Solution {
    List<List<Integer>> res = new ArrayList<>();
    List<Integer> path = new ArrayList<>();
    public List<List<Integer>> subsetsWithDup(int[] nums) {
        Arrays.sort(nums);//先排序,有利于去重
        boolean[] use = new boolean[nums.length];// use[i]=true,表示该位置已经被用过了
        backTracking(nums, 0, use);
        return res;
    }

    public void backTracking(int[] nums, int startIndex, boolean[] use){
        res.add(new ArrayList<>(path));//要找的是每个节点,而不仅是叶子节点
        if (startIndex >= nums.length){
            return;
        }
        for (int i = startIndex; i < nums.length; i++) {
            if (i>0 && nums[i-1] == nums[i] && use[i-1]==false){// 树层去重,如[1,2,2],第一个2已经走过了,就不走第二个 2 了
                continue;
            }
            path.add(nums[i]);
            use[i] = true;
            backTracking(nums, i+1, use);
            path.remove(path.size()-1);
            use[i] = false;
        }
    }
}
相关推荐
爱coding的橙子4 分钟前
每日算法刷题Day27 6.9:leetcode二分答案2道题,用时1h20min
算法·leetcode·职场和发展
GalaxyPokemon15 分钟前
LeetCode - 3. 无重复字符的最长子串
算法·哈希算法·散列表
a.30223 分钟前
C++ 时间处理指南:深入剖析<ctime>库
数据结构·c++·算法
亮亮爱刷题32 分钟前
算法刷题-回溯
算法
Neil今天也要学习1 小时前
永磁同步电机无速度算法--自适应龙贝格观测器
算法
算AI3 小时前
AI辅助编程:常用的7种Prompt模式
人工智能·算法
TY-20253 小时前
机器学习算法_决策树
算法·决策树·机器学习
子豪-中国机器人3 小时前
C++ 信息学奥赛总复习题
java·jvm·算法
全干engineer5 小时前
web3-基于贝尔曼福特算法(Bellman-Ford )与 SMT 的 Web3 DeFi 套利策略研究
算法·金融·web3·去中心化·区块链·智能合约
Splendid5 小时前
Geneformer:基于Transformer的基因表达预测深度学习模型
javascript·算法