Cod sursa(job #2003211)

Utilizator mirelPmirel p mirelP Data 22 iulie 2017 12:11:52
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.68 kb
#include <fstream>
#include <vector>

using namespace std;
const int NMAX=100000;
vector<int>G[NMAX+5];
int viz[NMAX+5];
ifstream fin("dfs.in");
ofstream fout("dfs.out");

void dfs(int u,int cc)
{
    int v;
    viz[u]=cc;
    for(int j=0;j<G[u].size();j++)
    {
        v=G[u][j];
        if(!viz[v])
            dfs(v,cc);
    }
}

int main()
{
    int n,m,v,u,i,cc=0;
    fin>>n>>m;
    for(i=1;i<=m;i++)
    {
        fin>>u>>v;
        G[u].push_back(v);
        G[v].push_back(u);
    }

    for(i=1;i<=n;i++)
        if(!viz[i])
    {
        ++cc;
        dfs(i,cc);
    }
    fout<<cc;
    fin.close();
    fout.close();

    return 0;
}