Cod sursa(job #1704139)

Utilizator larecursividadLa Recursividad larecursividad Data 18 mai 2016 09:57:00
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.9 kb
#include <fstream>
#include <vector>
#define InFile  "dfs.in"
#define OutFile "dfs.out"
#define MAX 100001

using namespace std;

void DFS (unsigned int node);

unsigned int N, M;
unsigned int X, Y;

vector < unsigned int > G[MAX];
bool used[MAX];
unsigned int i;

unsigned int solution;

int main ()
{
    ifstream fin (InFile);
    fin >> N >> M;
    for (i=1; i<=M; i++)
    {
        fin >> X >> Y;
        G[X].push_back(Y);
        G[Y].push_back(X);
    }
    fin.close();
    for (i=1; i<=N; i++)
        if (!used[i])
        {
            DFS(i);
            solution++;
        }
    ofstream fout (OutFile);
    fout << solution;
    fout.close();
    return 0;
}

void DFS (unsigned int node)
{
    vector < unsigned int > :: iterator j;
    used[node] = 1;
    for (j=G[node].begin(); j!=G[node].end(); j++)
        if (!used[*j])
            DFS(*j);
}