LeetCode--90.子集II(回溯算法)

90.子集II

题目描述

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

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

示例 1:

复制代码
输入:nums = [1,2,2]
输出:[[],[1],[1,2],[1,2,2],[2],[2,2]]

示例 2:

复制代码
输入:nums = [0]
输出:[[],[0]]

提示:

  • 1 <= nums.length <= 10
  • -10 <= nums[i] <= 10

代码

java 复制代码
class Solution {

    // 存放最终结果
    List<List<Integer>> result = new ArrayList<>();

    // 当前路径(当前子集)
    List<Integer> path = new LinkedList<>();


    /**
     * 回溯函数
     *
     * @param nums 排序后的数组
     * @param startIndex 本层递归开始的位置
     * @param used 记录当前路径中哪些元素被使用过
     */
    public void backtracking(int[] nums, int startIndex, int[] used){

        // 每到一个节点,都把当前路径加入结果
        result.add(new LinkedList<>(path));

        // 横向遍历(同一树层)
        for(int i = startIndex; i < nums.length; i++){

            /**
             * 树层去重(核心)
             *
             * nums[i] == nums[i - 1]
             *      说明当前元素和前一个元素相同
             *
             * used[i - 1] == 0
             *      说明前一个元素已经回溯结束
             *      即:
             *      前一个元素和当前元素处于同一树层
             *
             * 同一层中,相同元素只取第一个
             */
            if(i > startIndex
                    && nums[i - 1] == nums[i]
                    && used[i - 1] == 0){
                continue;
            }

            // 做选择
            path.add(nums[i]);

            // 标记当前元素已使用(进入树枝)
            used[i] = 1;

            // 递归下一层
            backtracking(nums, i + 1, used);

            // 回溯:撤销选择
            used[i] = 0;

            // 删除当前路径最后一个元素
            path.removeLast();
        }
    }

    public List<List<Integer>> subsetsWithDup(int[] nums) {

        // 必须先排序
        // 这样相同元素才会相邻,才能进行去重
        Arrays.sort(nums);

        // used数组:
        // 1 表示当前元素在当前路径中
        // 0 表示当前元素不在当前路径中
        int[] used = new int[nums.length];

        backtracking(nums, 0, used);

        return result;
    }
}
相关推荐
旖-旎1 小时前
《LeetCode 417 太平洋大西洋水流问题 FloodFill DFS 解法》
c++·算法·深度优先·力扣·floodfill
凌波粒2 小时前
LeetCode--46.全排列(回溯算法)
数据结构·算法·leetcode
2zcode2 小时前
项目文档:基于MATLAB语音信号变声算法设计与实现
算法·matlab·语音识别
指令集梦境2 小时前
图解:单调栈算法模板(Java语言)
java·开发语言·算法
生成论实验室2 小时前
自动驾驶:一个自主运动的系统
人工智能·算法·机器学习·语言模型·机器人·自动驾驶·安全架构
sheeta19982 小时前
LeetCode 每日一题笔记 日期:2026.06.16 题目:3612. 字符串特殊符号处理
笔记·算法·leetcode
CoderYanger2 小时前
A.每日一题:2095. 删除链表的中间节点
java·数据结构·程序人生·leetcode·链表·面试·职场和发展
青山木2 小时前
Hot 100 --- 矩阵置零
线性代数·算法·leetcode·矩阵·哈希算法
Jasmine_llq2 小时前
《B4264 [GESP202503 四级] 二阶矩阵》
线性代数·算法·矩阵·二维矩阵遍历枚举所有2×2矩阵·交叉乘积等式条件判断·输入输出快读加速·长整型防溢出计数统计