LeetCode第78题子集

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

分析一波题目

这个题目求子集,和之前做过组合相关的题目类似,因为子集也是组合,这个题目就非常简单了,还是一样的套路,我们只要把组合想成一棵树遍历就可以了。我们会发现子集就是树上所有的节点

比如[1,2,3,4] 的子集,我们用树可以表示出如下树:

树上所有的节点都是子集。

本题解题技巧

1、将子集也转换成组合问题,这样就可以通过遍历树求出子集了。

编码解决

java 复制代码
class Solution {
    List<List<Integer>> result = new ArrayList<>();
    public List<List<Integer>> subsets(int[] nums) {
        
        int n = nums.length;
       
        List<Integer> subResult= new ArrayList<>();
        getSubResult( subResult, 0,nums,n);
        return result;
    }

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

总结

1、任何求组合相关的题目,可以考虑转换成树,我们把树图一画,就能想到一些解题思路

相关推荐
white-persist3 分钟前
【vulhub weblogic CVE-2017-10271漏洞复现】vulhub weblogic CVE-2017-10271漏洞复现详细解析
java·运维·服务器·网络·数据库·算法·安全
不爱吃炸鸡柳4 分钟前
[特殊字符]C/C++内存管理深度解剖:从内存布局到new/delete底层,吃透面试必考核心
c语言·c++·面试
汀、人工智能4 分钟前
[特殊字符] 第9课:三数之和
数据结构·算法·数据库架构·图论·bfs·三数之和
汀、人工智能4 分钟前
[特殊字符] 第10课:接雨水
数据结构·算法·数据库架构·图论·bfs·接雨水
希望永不加班9 分钟前
SpringBoot 整合 MongoDB
java·spring boot·后端·mongodb·spring
故事和你9114 分钟前
蓝桥杯-2025年C++B组国赛
开发语言·软件测试·数据结构·c++·算法·职场和发展·蓝桥杯
py有趣21 分钟前
力扣热门100题之合并区间
算法·leetcode
cpp_250127 分钟前
P10108 [GESP202312 六级] 闯关游戏
数据结构·c++·算法·动态规划·题解·洛谷·gesp六级
Lzh编程小栈31 分钟前
数据结构与算法之队列深度解析:循环队列+C 语言硬核实现 + 面试考点全梳理
c语言·开发语言·汇编·数据结构·后端·算法·面试
AbandonForce33 分钟前
模拟实现vector
开发语言·c++·算法