算法训练营64-图论-深度优先优先搜索(dfs)-广度优先搜索(bfs)

题目:98. 所有可达路径 (kamacoder.com)

邻接矩阵表示图

复制代码
#include<bits/stdc++.h>

using namespace std;

vector<vector<int>> reslut;
vector<int> path;

void dfs(vector<vector<int>>& map, int start, int end) {
    if(start == end) {
        reslut.push_back(path);
        return;
    }
    for(int i = 1;i < map.size();i++) {
        if(map[start][i] == 1) {
            path.push_back(i);
            dfs(map, i, end);
            path.pop_back();
        }
    }
}


int main() {
    int n, m;
    cin >> n >> m;
    vector<vector<int>> map(n + 1, vector<int>(n + 1, 0));
    for(int i = 0;i < m;i++) {
        int x,y;
        cin >> x >> y;
        map[x][y] = 1;
    }
    path.push_back(1);
    dfs(map, 1, n);
    if(reslut.size() == 0) cout << -1 << endl;
    else {
        for(int i = 0;i < reslut.size();i++) {
            for(int j = 0;j < reslut[i].size() - 1;j++) {
                cout << reslut[i][j] << ' ';
            }
            cout << reslut[i][reslut[i].size() - 1] << endl;
        }
    }
    return 0;
}

邻接表表示图:

复制代码
#include <iostream>
#include <vector>
#include <list>
  
using namespace std;
  
vector<vector<int>> result;
vector<int> path;
  
void dfs(vector<list<int>>& map, int x, int n) {
    if(x == n) {
        result.push_back(path);
        return;
    }
    for(int i : map[x]) {
        path.push_back(i);
        dfs(map, i, n);
        path.pop_back();
    }
}
   
int main() {
    int n, m, x, y;
    cin >> n >> m;
    
    vector<list<int>> graph(n + 1);
    while(m--) {
        cin >> x >> y;
        graph[x].push_back(y);
    }
    path.push_back(1);
    dfs(graph, 1, n);
    if(result.size() == 0) cout << -1 << endl;
    else {
        for(int i = 0;i < result.size();i++) {
            int size = result[i].size();
            for(int j = 0;j < size - 1;j++) {
                cout << result[i][j] << ' ';
            }
            cout << result[i][size - 1] << endl;
        }        
    }
 
    return 0;
}
相关推荐
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕2 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
通信小呆呆3 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人