Cod sursa(job #1332930)

Utilizator Andrei_TirpescuAndrei Tirpescu Andrei_Tirpescu Data 2 februarie 2015 16:26:13
Problema Parcurgere DFS - componente conexe Scor 60
Compilator cpp Status done
Runda Arhiva educationala Marime 0.73 kb
#include <fstream>
#include <vector>
#define NMAX 100004
using namespace std;

ifstream fin("dfs.in");
ofstream fout("dfs.out");

int n, m;
vector<int> A[NMAX];
bool uz[NMAX];
int nrsol;

void init();
void DFS(int);

int main(){
    init();

    int i;
    for(i = 1; i<= n; ++i){
        if(!uz[i]){
            ++nrsol;
            DFS(i);
        }
    }

    fout<<nrsol<<'\n';

    return 0;
}


void init(){
    fin>>n>>m;

    int i, x, y;
    for(i = 1; i<=n; ++i){
        fin>>x>>y;
        A[x].push_back(y);
        A[y].push_back(x);
    }
}

void DFS(int k){
    uz[k] = 1;
    int i;
    for(i = 0; i< A[k].size(); ++i)
        if(!uz[ A[k][i] ])
            DFS(A[k][i]);
}