Cod sursa(job #2789816)

Utilizator Andreea__Zavoiu Andreea Andreea__ Data 28 octombrie 2021 00:00:29
Problema BFS - Parcurgere in latime Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.61 kb
#include <iostream>
#include <fstream>
#include <queue>
// #define nMax 100000
using namespace std;

ifstream fin("bfs.in");
ofstream fout("bfs.out");

vector<int> LA[100001]; // lista de adiacenta sub forma unui array de vectori de inturi => lista de liste
int n, m, s, viz[100001]={-1};//, rezultat[100001], dist;

void bfs(int start) { // pot optimiza eliminand argumentul start, pt ca stiu mereu ca e s dat?
    queue<int> Q;
    Q.push(start);
    viz[start]++; // am facut deja incrementarea in main pt s

    while (!Q.empty()){
        int nodCurent = Q.front(); // primul la coada
        Q.pop();

        for (int vecin : LA[nodCurent]) {
            if (viz[nodCurent]>-1) { // daca e vizitat, nu mai e -1 in el, ci mai mult
                viz[vecin] = 1 + viz[nodCurent]; // asa calculez distanta fata de start
                Q.push(vecin);
                //dist ++; // pentru fiecare vecin nevizitat creste cu 1 distanta fata de cat era anterior
                //rezultat[vecin] = dist;
            }
        }
    }
}

int main()
{
    int x, y, j=0;
    fin >> n >> m >> s;

    //for (int i=0; i<n; i++) { rezultat[i] = -1; } // il initializez cu -1 pentru cazul in care nu se poate ajunge la el din s
    //rezultat[s] = dist; // drumul de la s la s e 0

    for (int i=0; i<m; i++){
        fin >> x >> y;
        LA[x].push_back(y); // x se leaga si cu y, printre alte noduri
    }

    bfs(s);

    for (int i=0; i<n; i++){ // pentru fiecare nod
        //rezultat[i] = -1; // initializez cu -1 pentru cazul in care nu se poate ajunge la el din s
        fout << viz[i] << " ";
    }

    fout.close();
    return 0;
}