代码随想录算法训练营 | 所有可达路径
所有可达路径
文章链接: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数组,用来记录已经访问过的节点。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构