Cod sursa(job #3156004)

Utilizator Minutzu432Chirus Mina Sebastian Minutzu432 Data 10 octombrie 2023 13:33:04
Problema BFS - Parcurgere in latime Scor 30
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.91 kb
#include <iostream>
#include <vector>
#include <fstream>
#include <queue>
#include <algorithm>

using namespace std;
const int NMAX = 100;
vector<int> G[NMAX + 1];

int main() {
    ifstream in("bfs.in");
    ofstream of("bfs.out");
    int N, M, S;
    in >> N >> M >> S;

    for (int i = 0; i < M; ++i) {
        int x, y;
        in >> x >> y;
        G[x].push_back(y);
    }

    int d[NMAX + 1] = {-1};
    int viz[NMAX + 1] = {0};

    queue<int> q;
    q.push(S);
    viz[S] = 1;

    while (!q.empty()) {
        int next = q.front();
        q.pop();
        for (auto v : G[next]) {
            cout<<next<<": "<<v<<endl;
            if (viz[v] == 0) {
                q.push(v);
                viz[v] = 1;
                d[v] = d[next] + 1;

            }
        }
    }

    for (int i = 1; i <= N; ++i) {
        if(d[i]==0 && i != S){
            d[i]=-1;
        }
        of << d[i] << " ";
    }

    return 0;
}