Cod sursa(job #644433)

Utilizator Sebishor9Godja Sebastian Sebishor9 Data 6 decembrie 2011 16:48:42
Problema Parcurgere DFS - componente conexe Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 0.91 kb
#include <fstream>

using namespace std;

int n, m, ni,cn, a[2000][2000], v[2000];
ofstream fo("dfs.out");

void DFS (int nc) {
  int i;

// Se afiseaza nodul curent.
  for (i = 1;i <= n;i++)// pentru fiecare nod
    if (v[i] == 0 and a[nc][i]) { // 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,cn=0;
  ifstream fi("dfs.in");

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