递归、搜索与回溯-穷举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;
    //};
}
相关推荐
小镇cxy1 小时前
小模型微调过程
机器学习·aigc
知其然亦知其所以然1 小时前
Java 也能玩高质量 AI 绘图?SpringAI + Azure OpenAI 真香警告!
后端·spring·机器学习
f***6511 小时前
spring 跨域CORS Filter
java·后端·spring
hhwyqwqhhwy1 小时前
linux 设备树内容和plateform_device
java·linux·数据库
黑客思维者1 小时前
底层冗余性原理探秘模型剪枝(Pruning)为何能“无损”压缩模型?
算法·机器学习·剪枝
Overt0p1 小时前
抽奖系统 (1)
java·spring boot·spring·java-ee·java-rabbitmq
c***69301 小时前
SpringCloudGateWay
java
子豪-中国机器人1 小时前
C++自定义结构体学习方法:
java·开发语言
August_._1 小时前
【软件安装教程】Node.js 开发环境搭建详解:从安装包下载到全局配置,一篇搞定所有流程
java·vue.js·windows·后端·node.js·配置