Cod sursa(job #2840281)

Utilizator ps2001Silviu Popescu ps2001 Data 27 ianuarie 2022 12:06:20
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.67 kb
#include <bits/stdc++.h>

using namespace std;

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

vector<int> viz;
vector<vector<int>> gr;

void dfs(int node) {
    viz[node] = 1;
    for (auto &x : gr[node]) {
        if (!viz[x])
        dfs(x);
    }
}

int main() {
    int n, m;
    fin >> n >> m;

    gr = vector<vector<int>>(n + 1);
    viz = vector<int>(n + 1);
    for (int i = 0; i < m; i++) {
        int u, v;
        fin >> u >> v;
        gr[u].push_back(v);
        gr[v].push_back(u);
    }

    int cnt = 0;
    for (int i = 1; i <= n; i++) {
        if (!viz[i]) {
            dfs(i);
            cnt++;
        }
    }

    fout << cnt << '\n';
    return 0;
}