LeetCode第90题子集II

继续打卡算法题,今天学习的是LeetCode第90题子集II,这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

之前学习过78题子集,本题和78题只有一个不同,就是本题中元素是可以重复的,那么我们就需要去重了。

我们可以发现,在同一层如果出现相同的需要去重。我们可以使用boolean数组表示某个元素在某一层是否使用过。

本题解题技巧

1、通过树结构表达求子集组合的过程,对同一层的元素进行去重,避免重复的子集

编码解决

java 复制代码
class Solution {

     List<List<Integer>> result = new ArrayList<>();


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

        int n = nums.length;
        boolean[] used = new boolean[n];
        List<Integer> subResult= new ArrayList<>();
        getSubResult( subResult, 0,nums,n, used);
        return result;

    }

 

    public void getSubResult( List<Integer> subResult,int start,int[] nums,int n,boolean[] used) {
        
        //满足了组合条件,是一个子集
        result.add(subResult);
        //遍历到最后一个元素了,除了自己,没有其他组合了,需要结束
        if(start >= n) {
            return;
        }
        
        for(int i=start; i<n; i++) {
            //同一层去重
            if (i > 0 && nums[i] == nums[i - 1] && used[i - 1] == false) {
                continue;
            }
            List<Integer> tempSubResult= new ArrayList<>();
            tempSubResult.addAll(subResult);
            tempSubResult.add(nums[i]);
            used[i] = true;
            //递归
            getSubResult( tempSubResult, i+1,nums,n, used);
            //开始遍历下一层了
            used[i] = false; 
        }    
    }
}

总结

1、子集问题,画图之后就好理解了,先理思路再画图就能比较好的求解。

相关推荐
一块小土坷垃1 分钟前
最近发现了一款很好玩的SBTI测试的APP
面试·职场和发展·sbti
zjeweler3 分钟前
“网安+护网”终极300多问题面试笔记-2共3-计算机网络相关 - 好淘云
笔记·计算机网络·web安全·面试·职场和发展·护网行动·护网面试
小O的算法实验室4 分钟前
2022年IEEE TITS,基于 VRP 优化模型的城市轨道交通智能物流车辆配送路径优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
_日拱一卒10 分钟前
LeetCode:206反转链表
算法·leetcode·链表
马丁玩编程12 分钟前
从程序员到AI工程师:距离有多远?附全套学习路线图
后端·程序员·aigc
我不是懒洋洋17 分钟前
【经典题目】链表OJ(轮转数组、返回倒数第k个节点、链表的回文结构)
c语言·开发语言·数据结构·算法·链表·visual studio
SteveSenna17 分钟前
aubo i5+pika realsense+ACT训练完整流程
人工智能·学习·算法·机器人
rannn_11117 分钟前
【Redis|高级篇2】多级缓存|JVM进程缓存、Lua语法、多级缓存实现(OpenResty)、缓存同步(Canal)
java·redis·分布式·后端·缓存·lua·openresty
We་ct18 分钟前
EventSource & WebSocket & HTTP
前端·javascript·网络·websocket·网络协议·http·面试
黑牛儿22 分钟前
2026 MySQL 面试 100 题: 索引 / 事务 / 锁(答案 + 原理)
android·mysql·面试