递归、搜索与回溯-穷举vs暴搜vs深搜vs回溯vs剪枝:13.子集

题目链接:78. 子集(中等)

算法原理:

解法:递归

Java代码:

java 复制代码
/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: 王洋
 * Date: 2025-09-25
 * Time: 00:06
 */
class Solution {
    //自己按着解法二写的,一遍通过
    List<List<Integer>> ret;
    List<Integer> path;
    public List<List<Integer>> subsets(int[] nums) {
        ret=new ArrayList<>();
        path=new ArrayList<>();
        dfs(nums,0);
        return ret;
    }
    public void dfs(int[] nums,int pos){
        ret.add(new ArrayList<>(path));
        for(int i=pos;i<nums.length;i++){
            path.add(nums[pos++]);
            dfs(nums,pos);
            //回溯
            path.remove(path.size()-1);
        }
        return ;
    }
    //看吴小哲敲完后写的,注释处是自己写的解法一,但失败了
    List<List<Integer>> ret;
    List<Integer> path;
    public List<List<Integer>> subsets(int[] nums) {
        ret=new ArrayList<>();
        path=new ArrayList<>();
        dfs(nums,0);
        return ret;
    }
    public void dfs(int[] nums,int pos){
        if(pos==nums.length){ ret.add(new ArrayList<>(path));return;}
        //选
        path.add(nums[pos]);
        dfs(nums,pos+1);
        path.remove(path.size()-1);//回溯->恢复原状
        //不选
        dfs(nums,pos+1);
    }
    //public void dfs(int[] nums,int i){
    //    if(i==nums.length) {ret.add(new ArrayList<>(path));path.add(i);}
    //    for(;i<nums.length;i++) dfs(nums,i);
    //    return;
    //};
}
相关推荐
xqqxqxxq6 小时前
Java AI智能P图工具技术笔记
java·人工智能·笔记
谷雨不太卷6 小时前
进程的状态码
java·前端·算法
顾温6 小时前
default——C#/C++
java·c++·c#
空中海7 小时前
02 ArkTS 语言与工程规范
java·前端·spring
楚国的小隐士7 小时前
在AI时代,如何从0接手一个项目?
java·ai·大模型·编程·ai编程·自闭症·自闭症谱系障碍·神经多样性
散峰而望7 小时前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
躺不平的理查德7 小时前
时间复杂度与空间复杂度备忘录
数据结构·算法
yaki_ya7 小时前
yaki-C语言:从概念基础到内存解析---数组(array)完全指南
java·c语言·算法
刃神太酷啦7 小时前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode
亚历克斯神7 小时前
Java 25 模式匹配增强:让代码更简洁优雅
java·spring·微服务