Cod sursa(job #1828986)

Utilizator mateigabriel99Matei Gabriel mateigabriel99 Data 14 decembrie 2016 10:27:39
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.66 kb
#include <iostream>
#include <fstream>
#include <vector>

#define NMax 100001

using namespace std;

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

int N,M;
vector<int> G[NMax];
bool v[NMax];

void Read();

void DFS(int k)
{
    v[k]=1;
    for(int i=0;i<G[k].size();i++)
        if(v[G[k][i]]==0)
            DFS(G[k][i]);
}
int main()
{
    Read();

    int conexe=0;
    for(int i=1;i<=N;i++)
        if(v[i]==0)
            DFS(i),conexe++;
    fout<<conexe;

    return 0;
}

void Read()
{
    fin>>N>>M;
    for(int i,j,k=1;k<=M;k++)
    {
        fin>>i>>j;
        G[i].push_back(j);
        G[j].push_back(i);
    }
}