Cod sursa(job #1523296)

Utilizator Paul9807Herman Paul Paul9807 Data 12 noiembrie 2015 16:24:00
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.79 kb
#include<iostream>
#include<fstream>
#include<vector>
using namespace std;
ifstream fin("dfs.in");
ofstream fout("dfs.out");

const int maxn=100005;

int n,m,cntConexe;
vector <int> g[maxn];
bool vizitat[maxn];
vector <int> comp[maxn];

void dfs(int node)
{
    vizitat[node]=1;
    cout<<node<<" ";
    for (int i=0;i<int(g[node].size());i++)
    {
        int vecin=g[node][i];
        if (!vizitat[vecin])
            dfs(vecin);
    }
}
int main ()
{
    fin>>n>>m;
    for (int i=1;i<=m;i++)
    {
        int x,y;
        fin>>x>>y;
        g[x].push_back(y);
        g[y].push_back(x);
    }
    for (int i=1;i<=n;i++)
    {
        if (!vizitat[i])
        {
            cntConexe++;
            dfs(i);
        }
    }
    fout<<cntConexe;
    return 0;
}