Cod sursa(job #1268590)

Utilizator juniorOvidiu Rosca junior Data 21 noiembrie 2014 06:23:25
Problema Parcurgere DFS - componente conexe Scor 45
Compilator cpp Status done
Runda Arhiva educationala Marime 0.85 kb
#include <fstream>

using namespace std;

int n, m, cc, l, c, i; // noduri, muchii, componente conexe
bool a[1000][1000], v[1000];
ifstream fin("dfs.in");
ofstream fout("dfs.out");

void DFS (int nc) {
  int i;

  for (i = 1; i <= n; i++) // pentru fiecare nod
    if (a[nc][i] and not v[i]) {// i este vecin nevizitat al nodului curent?
      v[i] = true; // Marcam i ca fiind vizitat.
      DFS(i); // Continuam parcurgerea in adancime.
    }
}

int main() {
  fin >> n >> m;  // Se citeste numarul de noduri si numarul de muchii.
  for (i = 1; i <= m; i++) { // Pentru fiecare muchie
    fin >> l >> c; // Se citesc informatiile despre o muchie.
    a[l][c] = a[c][l] = true;// Se actualizeaza matricea de adiacenta/
  }
  for (i = 1; i <= n; i++) {
    if (not v[i]) {
      v[i] = 1;
      cc++;
      DFS(i);
    }
  }
  fout << cc;
}