算法训练营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;
}
相关推荐
卡戎-caryon19 分钟前
【数据结构】06.栈&&队列
c语言·数据结构·算法·链表
山脚ice30 分钟前
【CT】LeetCode手撕—704. 二分查找
算法·leetcode
贱贱的剑1 小时前
【算法】选择排序
算法·rust·排序算法
瑜陀1 小时前
2024.06.30 刷题日记
数据结构·算法·leetcode
Star Patrick1 小时前
*算法训练(leetcode)第二十天 | 39. 组合总和、40. 组合总和 II、131. 分割回文串
c++·算法·leetcode
光久li1 小时前
【算法刷题 | 动态规划14】6.28(最大子数组和、判断子序列、不同的子序列)
算法·动态规划
飘然渡沧海1 小时前
gbk,ucs-2转中文
java·开发语言·算法
raykingl1 小时前
154. 寻找旋转排序数组中的最小值 II(困难)
java·python·算法·二分查找
raykingl1 小时前
69. x 的平方根(简单)
java·python·算法·二分查找
阳光男孩011 小时前
力扣974.和可被K整除的子数组
数据结构·算法·leetcode