Cod sursa(job #3182692)

Utilizator Radu_MocanasuMocanasu Radu Radu_Mocanasu Data 9 decembrie 2023 13:05:10
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.8 kb
#pragma GCC optimize("Ofast,inline,unroll-loops")
#include <bits/stdc++.h>

using namespace std;
ifstream fin("dfs.in");
ofstream fout("dfs.out");
int t[100002];
int h[100002];
int findr(int x){
    int r = x;
    while(r != t[r]) r = t[r];
    while(x != r){
        int d = t[x];
        t[x] = r;
        x = d;
    }
    return r;
}
void dsu(int x, int y){
    int rx = findr(x), ry = findr(y);
    if(h[rx] > h[ry]) t[ry] = rx;
    else{
        t[rx] = ry;
        if(h[rx] == h[ry]) h[ry]++;
    }
}
int main()
{
    int n,m,i,u,v,k = 0;
    fin >> n >> m;
    for(i = 1; i <= n; i++) t[i] = i;
    for(i = 1; i <= m; i++){
        fin >> u >> v;
        if(findr(u) != findr(v)) dsu(u,v);
    }
    for(i = 1; i <= n; i++) if(t[i] == i) k++;
    fout << k;
    return 0;
}