算法——图论:路径,回溯

. - 力扣(LeetCode)

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

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

即给定邻接表求0到n-1的所有路径。

自己的代码:dfs,来到当前节点先记录其路径。如果发现当前节点为最后节点则直接返回。否则,对当前节点的每个邻接节点不断dfs。dfs完成后,将当前节点从路径中删除并返回。

注意:此题无需判断节点是否访问过,因为本题是有向图,对于某个节点,指向该节点可能有好几个节点,所以如果该节点只被访问一次无法得到所有路径。

class Solution {
public:
    vector<vector<int>>res;

    vector<vector<int>> allPathsSourceTarget(vector<vector<int>>& graph) {
        vector<int> visited(graph.size(),0),path;
        dfs(graph,0,path,visited);
        return res;
    }

    void dfs(vector<vector<int>>& graph,int cur,vector<int> &path,vector<int>&visited)
    {
        path.push_back(cur);
        if(cur==graph.size()-1)
        {
            res.push_back(path);
            path.pop_back();
            return;
        }
        for(int i=0;i<graph[cur].size();i++)
        {
            //if(!visited[graph[cur][i]])
            dfs(graph,graph[cur][i],path,visited);
        }
        //visited[cur]=1;
        path.pop_back();
    }
};

官方题解:

我们可以使用深度优先搜索的方式求出所有可能的路径。具体地,我们从 0 号点出发,使用栈记录路径上的点。每次我们遍历到点 n−1,就将栈中记录的路径加入到答案中。

特别地,因为本题中的图为有向无环图(DAG\text{DAG}DAG),搜索过程中不会反复遍历同一个点,因此我们无需判断当前点是否遍历过。

class Solution {
public:
    vector<vector<int>> ans;
    vector<int> stk;

    void dfs(vector<vector<int>>& graph, int x, int n) {
        if (x == n) {
            ans.push_back(stk);
            return;
        }
        for (auto& y : graph[x]) {
            stk.push_back(y);
            dfs(graph, y, n);
            stk.pop_back();
        }
    }

    vector<vector<int>> allPathsSourceTarget(vector<vector<int>>& graph) {
        stk.push_back(0);
        dfs(graph, 0, graph.size() - 1);
        return ans;
    }
};

整体思路差不多。

相关推荐

  1. 算法——路径回溯

    2024-03-30 12:44:05       18 阅读
  2. 算法————最短路径——Floyd / 传递闭包

    2024-03-30 12:44:05       31 阅读
  3. 搜索与:所有可达路径(DFS算法

    2024-03-30 12:44:05       8 阅读
  4. ——最短路径

    2024-03-30 12:44:05       24 阅读
  5. 算法算法模板

    2024-03-30 12:44:05       20 阅读
  6. 算法——:拓扑排序

    2024-03-30 12:44:05       18 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-30 12:44:05       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-30 12:44:05       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-30 12:44:05       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-30 12:44:05       20 阅读

热门阅读

  1. 了解监控易(13):数据库监控-功能模块解析

    2024-03-30 12:44:05       14 阅读
  2. python基础语法

    2024-03-30 12:44:05       18 阅读
  3. #设计模式#4.6 Flyweight(享元) 对象结构型模式

    2024-03-30 12:44:05       18 阅读
  4. 2024最新华为OD机试试题库全 -【跳马】- C卷

    2024-03-30 12:44:05       19 阅读
  5. Golang基础-3

    2024-03-30 12:44:05       17 阅读
  6. kanzi 3d知识点

    2024-03-30 12:44:05       18 阅读
  7. 了解HTTP安全标头(HTTP Security Headers)

    2024-03-30 12:44:05       18 阅读
  8. C++之常函数、常对象

    2024-03-30 12:44:05       15 阅读
  9. C 传递指针给函数

    2024-03-30 12:44:05       16 阅读