所有可能的路径_回溯法_java

所有可能的路径

leetcode链接

问题描述

给你一个有 n 个节点的 有向无环图(DAG),请你找出所有从节点 0 到节点 n-1 的路径并输出(不要求按特定顺序)

graphi 是一个从节点 i 可以访问的所有节点的列表(即从节点 i 到节点 graphij存在一条有向边)。

示例

示例 1:

输入:graph = \[1,2,3,3,\[\]]

输出:\[0,1,3,0,2,3]

解释:有两条路径 0 -> 1 -> 3 和 0 -> 2 -> 3

示例 2:

输入:graph = \[4,3,1,3,2,4,3,4,\[\]]

输出:\[0,4,0,3,4,0,1,3,4,0,1,2,3,4,0,1,4]

解题思路

采用深度优先进行路径搜索并用回溯法实现。

代码实现

java 复制代码
class Solution {
   //存放搜索过程中走过的节点
   List<Integer> path = new ArrayList<>();
   //存放所有可能路径
   List<List<Integer>> res = new ArrayList<>();

   public List<List<Integer>> allPathsSourceTarget(int[][] graph) {
       //处理0节点,将0节点放入走过的路径中
       path.add(0);

       //深度搜索0节点
       dfs(0, graph);

       return res;
   }

   //注意:此处graph也要传入用于判断节点之间是否有路径
   void dfs (int node, int[][] graph) {
       if (node == graph.length - 1) {
           //若已走到终点将可能路径传入结果集
           //注意:此处一定要用path新建一个对象后再存入res!
           res.add(new ArrayList<>(path));
           return;
       }

       for (int i = 0; i < graph[node].length; i++) {
           //处理graph[node][i]节点,将graph[node][i]节点放入走过的路径中
           path.add(graph[node][i]);

           //深度搜索该节点
           dfs(graph[node][i], graph);

           //回溯,将该节点移出可能路径,而后尝试对下一个节点的处理。
           path.remove(path.size() - 1);

       }

       return;
   }
}

注意事项

为什么一定要用path新建一个对象后再存入res?

因为如果直接将path存入res,则存入res的是path的引用。当所有的可能路径都搜索且回溯完毕后path = 0, 最后拿到的res将形如\[00, 0]。

复杂度

空间复杂度:O(n)

时间复杂度:O(n * 2^n)

th = 0, 最后拿到的res将形如\[00, 0]。

复杂度

空间复杂度:O(n)

时间复杂度:O(n * 2^n)

我们可以找到一种最坏情况,即每一个点都可以去往编号比它大的点。此时路径数为 O(2^n),且每条路径长度约为 O(n),因此总时间复杂度为 O(n * 2^n)。

相关推荐
好家伙VCC几秒前
Rust+Bioinfo:80ms极速SNP注释引擎
java·开发语言·算法·rust
啦哈拉哈1 分钟前
【Python】知识点零碎学习7
python·学习·算法
宝贝儿好3 分钟前
【NLP】第八章:项目实操案例:文本情感分析
人工智能·python·深度学习·算法·自然语言处理
ANnianStriver10 分钟前
PetLumina-AI 驱动的宠物生活管理平台
java·生活·vue3·springboot·ai编程·宠物·全栈开发
如竟没有火炬12 分钟前
恢复二叉搜索树
数据结构·数据库·python·leetcode·动态规划
好家伙VCC13 分钟前
Delta Lake + Flink 实现近实时数据湖 Schema 演化
java·大数据·flink
hoho_1216 分钟前
如何替换jar包中依赖的其他jar
java·pycharm·jar
如竟没有火炬16 分钟前
整数拆分——动态规划
开发语言·数据结构·python·算法·leetcode·动态规划
叫我:松哥17 分钟前
基于数据挖掘的旅游景点个性化推荐系统设计与实现,Apriori和FP-Growth算法挖掘景点之间的关联规则
人工智能·python·算法·数据挖掘·数据分析·beautifulsoup
码语智行17 分钟前
接口请求处理流程
java