力扣 全排列

回溯经典例题。

题目

通过回溯生成所有可能的排列。每次递归时,选择一个数字,直到选满所有数字,然后记录当前排列,回到上层时移除最后选的数字并继续选择其他未选的数字。每次递归时,在 path 中添加一个新的数字,直到 path 的长度等于数组 nums 的长度,此时可以将 path 添加到结果集中。当递归深入到某一层时,我们在返回上层前移除 path 中最后添加的数字,恢复现场,尝试其他未选的数字。用循环遍历,然后每次把已加过的数做剔除去选。

记住,dfs递归时会逐层进入,即进入后遇到dfs便会进入下一个dfs,逐渐挖到最深层,然后在出口处加入结果集。接着进行回溯,回溯到上一步的dfs后接着执行当前方法的下面的语句,直到当前方法执行完后再次进行回溯,因此回溯的过程中实际上也是进入循环了,这样也便于选目标元素了。然后递归一定要记得加入的是path副本,回溯时要做好恢复。

java 复制代码
class Solution {
    public List<List<Integer>> permute(int[] nums) {
        LinkedList<List<Integer>> res = new LinkedList<>();            //排列组合结果
        LinkedList<Integer> path = new LinkedList<>();                     //单个排列
        dfs(res,nums,path);
        return res;
    }

    public void dfs(List<List<Integer>> res, int[] nums, LinkedList<Integer> path){
        if(path.size() == nums.length){
            res.add( new ArrayList<Integer>(path) );     //对于每次添加的单个排列,应该都是不同的引用对象
        }
        for(int i=0; i<nums.length; i++){
            if(path.contains(nums[i]))  {continue;}              //当前层中,已添加的数不再考虑  
            path.add(nums[i]);                                   //未添加的数则存放
            dfs(res, nums, path);               //进入下一层(递归)
            path.removeLast();                                  //从深层节点向浅层节点回溯
        }
    }
}
相关推荐
Jul1en_1 分钟前
【SpringCloud】SkyWalking 链路追踪知识详解及部署教程
java·后端·spring·spring cloud·skywalking
宸津-代码粉碎机1 分钟前
Spring AI 企业级实战|智能记忆摘要+自动遗忘机制落地,彻底解决上下文爆炸与Token冗余
java·大数据·人工智能·后端·python·spring·云计算
快手技术4 分钟前
征集令|快手探索者LLM-Rec挑战赛正式发布!
算法
逻极18 分钟前
Spring Boot 微服务开发提速:我们如何将接口响应时间降低60%
java·spring boot·微服务·性能优化·自动配置
Yvonne爱编码19 分钟前
JAVA EE初阶---DAY 2 计算机网络
java·开发语言·计算机网络·算法·java-ee·php
潇凝子潇28 分钟前
IDEA插件
java·ide·intellij-idea
摇滚侠29 分钟前
SSM 框架实战教程 SpringBoot 自动配置 176-179
java·spring boot·后端
JAVA96531 分钟前
JAVA面试-JVM篇 02-G1垃圾收集器的工作原理是什么与CMS的区别
java·jvm·面试
ywl47081208733 分钟前
spring单列bean之循环依赖核心源码解读
java·后端·spring
我命由我1234533 分钟前
RFID 技术极简理解
java·c语言·c++·嵌入式硬件·物联网·visualstudio·java-ee