Cod sursa(job #1356280)

Utilizator CalinCojoFMI Cojocaru Calin George CalinCojo Data 23 februarie 2015 12:29:56
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.2 kb
#include <iostream>
#include <fstream>
#include <deque>
#include <vector>
#define pb push_back
#define pf push_front
#define l 10
// determinarea componentelor conexe ale unui graf;
using namespace std;
int viz[100005];
vector <int> vecini[100005];
deque <int> stiva;

void DFS( int nod){
   int i,gasit,x;
   viz[nod] = 1;
   stiva.pf (nod);
   while(!stiva.empty()){

    i = 1 ;gasit = 0; x =stiva.front();

    for( i = 0  ; i < vecini[x].size(); i++){
        if(viz[vecini[x][i]]!=1)                  // cautam un element ce nu a fost vizita
        {                                                  // daca am gasit intrerupe si adaugam in stiva
            viz[vecini[x][i]] = 1;
            gasit = 1;
            break;
        }
    }

    if(gasit){
        stiva.pf (vecini[x][i]);
    }
    else{
        stiva.pop_front();
    }
   }

}

int main()
{
    int n,m,x,y,sol = 0;
    ifstream f("dfs.in",ios::in);
    ofstream g("dfs.out",ios::out);
    f>>n>>m;
    for(int i = 1; i <= m; i++){
        f>>x>>y;
        vecini[x].pb(y);
        vecini[y].pb(x);
    }
    for( int i = 1 ;i <= n; i++)
        if(viz[i]==0){
            DFS(i);
            sol++;
        }

    g<<sol;
    return 0;
}