Cod sursa(job #644417)

Utilizator levaionutLeva Ionut levaionut Data 6 decembrie 2011 16:02:06
Problema Parcurgere DFS - componente conexe Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.88 kb
#include <fstream>
#include <iostream>
using namespace std;

int n, m, ni, a[2000][2000], v[2000],cc;

void DFS (int nc) {
  int i;
  // Se afiseaza nodul curent.
  for (i = 1;i <= n;i++)// pentru fiecare nod
    if (a[nc][i]==1 and v[i] == 0){// i este vecin nevizitat al nodului curent?
      v[i] = 1;// Marcam i ca fiind vizitat.
  DFS(i);// Continuam parcurgerea in adancime.
}
}
int main() {
  int i, l, c;
  ifstream fi("df2.in");

  fi >> n; fi >> m;// Se citeste numarul de noduri si numarul de muchii.
  for (i = 1;i <= m;i++) {// Pentru fiecare muchie
    fi >> l;fi >> c;// Se citesc informatiile despre o muchie.
    a[l][c] = 1;a[c][l] = 1;
  }
  for(i=1;i<=n;i++){
    v[1]=1;// Se actualizeaza matricea de adiacenta/// Se citeste nodul initial
  if(v[i] == 0){
    cc++;// Se marcheaza nodul initial ca fiind vizitat.
  DFS(i);
  }
  }
  cout<<cc;
}