【LeetCode刷题】-- 78.子集

78.子集

java 复制代码
class Solution {
    public List<List<Integer>> subsets(int[] nums) {
        List<List<Integer>> ans = new ArrayList<>();
        List<Integer> list = new ArrayList<>();
        dfs(0,nums,ans,list);
        return ans;
    }
    private void dfs(int cur,int[] nums,List<List<Integer>> ans,List<Integer> list){
        //每更新一次List,都加入结果,首先加进来的是空集
        ans.add(new ArrayList<>(list));
        for(int i = cur;i<nums.length;i++){
            //将当前数加入List
            list.add(nums[i]);
            //递归,不能重复使用当前树,下一轮从i+1开始
            dfs(i+1,nums,ans,list);
            //回溯,回退刚刚加到的数
            list.remove(list.size()-1);
        } 
    }
}
相关推荐
一个不知名程序员www10 小时前
算法学习入门 --- 哈希表和unordered_map、unordered_set(C++)
c++·算法
Sarvartha10 小时前
C++ STL 栈的便捷使用
c++·算法
夏鹏今天学习了吗11 小时前
【LeetCode热题100(92/100)】多数元素
算法·leetcode·职场和发展
飞Link11 小时前
深度解析 MSER 最大稳定极值区域算法
人工智能·opencv·算法·计算机视觉
bubiyoushang88812 小时前
基于CLEAN算法的杂波抑制Matlab仿真实现
数据结构·算法·matlab
2401_8948281212 小时前
从原理到实战:随机森林算法全解析(附 Python 完整代码)
开发语言·python·算法·随机森林
Remember_99313 小时前
【LeetCode精选算法】前缀和专题二
算法·哈希算法·散列表
源代码•宸13 小时前
Leetcode—509. 斐波那契数【简单】
经验分享·算法·leetcode·面试·golang·记忆化搜索·动规
博大世界13 小时前
matlab结构体数组定义
数据结构·算法
Loo国昌14 小时前
【LangChain1.0】第九阶段:文档处理工程 (LlamaIndex)
人工智能·后端·python·算法·langchain