代码随想录算法训练营 | 所有可达路径

所有可达路径

文章链接:https://programmercarl.com/kamacoder/0098.所有可达路径.html#本题代码
题目链接:https://kamacoder.com/problempage.php?pid=1170

#include <iostream>
#include <vector>
using namespace std;

//全局路径
vector<vector<int>> paths;
vector<int> path;

void dfs(vector<vector<int>> graph,vector<bool> &visited,int x,int n){
    //递归结束条件
    if(x==n){
        paths.push_back(path);
        return;
    }
    for(int i=1;i<=n;i++){
        if(graph[x][i]==1&&visited[i]==false){
            path.push_back(i);
            visited[i]=true;
            dfs(graph,visited,i,n);
            visited[i]=false;//回溯
            path.pop_back();//回溯
        }
    }
}

int main(){
    int n,m;
    cin>>n>>m;
    //创建n*n的邻接矩阵
    vector<vector<int>> graph(n+1,vector<int>(n+1,0));
    vector<bool> visited(n+1,false);
    while(m--){
        int s,t;
        cin>>s>>t;
        graph[s][t]=1;
    }
    //一开始就已经从节点1开始了,故这里初始化path,和visited[1]
    path.push_back(1);
    visited[1]=true;
    dfs(graph,visited,1,n);
    
    // 输出结果
    if (paths.size() == 0) cout << -1 << endl;
    for (const vector<int> &pa : paths) {
        for (int i = 0; i < pa.size() - 1; i++) {
            cout << pa[i] << " ";
        }
        cout << pa[pa.size() - 1]  << endl;
    }
    
}

总结:这里在随想录中没有将会形成环的路径排除,所以我加了一个visited数组,用来记录已经访问过的节点。

posted @ 2024-11-13 16:26  W-Vicky11  阅读(3)  评论(0编辑  收藏  举报