Cod sursa(job #1443366)

Utilizator horiainfoTurcuman Horia horiainfo Data 27 mai 2015 20:02:33
Problema Parcurgere DFS - componente conexe Scor 80
Compilator cpp Status done
Runda Arhiva educationala Marime 0.72 kb
#include <fstream>
#define NMAX 100000
#include <vector>
using namespace std;
ifstream fin("dfs.in");
ofstream fout("dfs.out");
int n,m,i,j,nrConex,x,y;
struct noduri{vector<int> lst; bool viz;} nod[NMAX];
void DFS(int poz)
{
    nod[poz].viz=1;
    for(int i=0;i<nod[poz].lst.size();i++)
    {
        int p=nod[poz].lst[i];
        if(nod[p].viz==0)
            DFS(p);
    }
}
int main()
{
    fin>>n>>m;
    for(int i=1;i<=m;i++)
    {
        fin>>x>>y;
        nod[x].lst.push_back(y);
        nod[y].lst.push_back(x);
    }
    for(int i=1;i<=n;i++)
    {
        if(nod[i].viz==0)
        {
            DFS(i);
            nrConex++;
        }
    }
    fout<<nrConex<<'\n';
    return 0;
}