Cod sursa(job #1112701)

Utilizator teo.serbanescuTeo Serbanescu teo.serbanescu Data 19 februarie 2014 22:54:38
Problema Parcurgere DFS - componente conexe Scor 15
Compilator cpp Status done
Runda Arhiva educationala Marime 0.87 kb
#include <fstream>
#include <vector>
#include <string.h>

using namespace std;

fstream f("dfs.in",ios::in);
fstream g("dfs.out",ios::out);

int const nmax=100005;

vector <int> a[nmax];

int n,m,i,j,x,y,nc,comp,viz[nmax];

void citire()
{
    f>>n>>m;
    for (i=1;i<=m;i++)
    {
        f>>x>>y;
        a[x].push_back(y);
    }
}

void rezolvare(int nc)
{
    for (vector<int>::iterator it=a[nc].begin();it!=a[nc].end();++it)
    {
        if(!viz[*it])
        {
            viz[*it]=1;
            rezolvare(*it);
        }
    }

}

int main()
{
    citire();
    comp=0;
    memset(viz,0,sizeof(viz));
    for (i=1;i<=n;i++) if (!viz[i]) {
                                        comp++;
                                        viz[i]=1;
                                        rezolvare(i);
    }
    g<<comp;

    return 0;
}