算法训练营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;
}
相关推荐
大千AI助手17 分钟前
蛙跳积分法:分子动力学模拟中的高效数值积分技术
算法·积分·数值积分·蛙跳积分法·牛顿力学系统·verlet积分算法
zycoder.24 分钟前
力扣面试经典150题day3第五题(lc69),第六题(lc189)
算法·leetcode·面试
西阳未落2 小时前
LeetCode——双指针
c++·算法
胖咕噜的稞达鸭3 小时前
C++中的父继子承:继承方式实现栈及同名隐藏和函数重载的本质区别, 派生类的4个默认成员函数
java·c语言·开发语言·数据结构·c++·redis·算法
笑口常开xpr3 小时前
【C++】模板 - - - 泛型编程的魔法模具,一键生成各类代码
开发语言·数据结构·c++·算法
IT小番茄4 小时前
Kubernetes云平台管理实战:自动加载到负载均衡(七)
算法
笑口常开xpr4 小时前
【C++继承】深入浅出C++继承机制
开发语言·数据结构·c++·算法
让我们一起加油好吗5 小时前
【基础算法】DFS
算法·深度优先
爱学习的小鱼gogo6 小时前
python 矩阵中寻找就接近的目标值 (矩阵-中等)含源码(八)
开发语言·经验分享·python·算法·职场和发展·矩阵
红纸2816 小时前
Subword算法之WordPiece、Unigram与SentencePiece
人工智能·python·深度学习·神经网络·算法·机器学习·自然语言处理