递归、搜索与回溯-穷举vs暴搜vs深搜vs回溯vs剪枝:12.全排列

题目链接:46. 全排列(中等)

算法原理:

解法:递归

Java代码:

java 复制代码
/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: 王洋
 * Date: 2025-09-24
 * Time: 21:09
 */
class Solution {
    //自己又写了一遍
    List<List<Integer>> ret;
    List<Integer> path;
    boolean[] check;
    public List<List<Integer>> permute(int[] nums) {
        ret=new ArrayList<>();
        path=new ArrayList<>();
        check=new boolean[nums.length];
        dfs(nums);
        return ret;
    }
    public void dfs(int[] nums){
        //递归出口:该路径达到了数目
        if(path.size()==nums.length){
            ret.add(new ArrayList<>(path));
            return ;
        }
        for(int i=0;i<nums.length;i++){
            if(check[i]==false){
                path.add(nums[i]);
                check[i]=true;
                dfs(nums);
                //回溯->恢复现场
                check[i]=false;
                path.remove(path.size()-1);
            }
        }
    }
}
相关推荐
Mr Tang5 分钟前
Docker日志查看和应用日志查看命令大全
java·开发语言
invicinble6 分钟前
java处理数据合集
java·开发语言
Narrastory8 分钟前
最大似然估计,香农熵,交叉熵与KL散度的详细解读与实现
人工智能·机器学习
GIS数据转换器21 分钟前
空天地一体化边坡监测及安全预警系统
大数据·人工智能·安全·机器学习·3d·无人机
Json_24 分钟前
springboot框架对接物联网,配置TCP协议依赖,与设备通信,让TCP变的如此简单
java·后端·tcp/ip
代码游侠26 分钟前
应用——MPlayer 媒体播放器系统代码详解
linux·运维·笔记·学习·算法
C+++Python31 分钟前
Java 锁机制
java·开发语言
czlczl2002092533 分钟前
Spring Security 6 :配置生产级 SecurityFilterChain
java·spring
Java小白,一起学习36 分钟前
AndroidStudio安装教程
java·android-studio
学编程就要猛37 分钟前
算法:3.快乐数
java·算法