Cod sursa(job #2198058)

Utilizator dianamichesaRosu Diana Michesa dianamichesa Data 23 aprilie 2018 15:00:03
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.65 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("dfs.in");
ofstream g("dfs.out");
const int N=100001,M=200001;
int lst[N],vf[2*M],urm[2*M],nr,viz[N],comp,n,m;
void adauga(int x,int y){
    vf[++nr]=y;
    urm[nr]=lst[x];
    lst[x]=nr;
}
void dfs(int x){
   viz[x]=comp;
   int p=lst[x],y;
   while(p!=0){
       y=vf[p];
       if(!viz[y])
          dfs(y);
        p=urm[p];
   }
}
int main()
{
    f>>n>>m;
    for(int i=1;i<=m;i++){
        int x,y;
        f>>x>>y;
        adauga(x,y);
        adauga(y,x);
    }
    for(int i=1;i<=n;i++)
        if(!viz[i]){
            comp++;
            dfs(i);
        }
    g<<comp;
    return 0;
}