Cod sursa(job #3248548)

Utilizator hiken056Stefan Rusu hiken056 Data 12 octombrie 2024 10:31:32
Problema Parcurgere DFS - componente conexe Scor 15
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.56 kb
#include <bits/stdc++.h>

using namespace std;

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

const int MAXN = 1e5 + 5;
int N, M, cont;
vector <int> G[MAXN];
bool viz[MAXN];

void dfs(int nod) {
    viz[nod] = 1;
    for ( auto it : G[nod] ) {
        if ( !viz[it] ) dfs(it);
    }
}

int main () {
    fin >> N >> M;
    int x, y;
    while ( M-- ) {
        fin >> x >> y;
        G[x].push_back(y);
    }
    for ( int i = 1; i <= N; ++ i ) {
        if ( !viz[i] ) {
            cont  ++;
            dfs(i);
        }
    }
    fout << cont;
    return 0;
}