Cod sursa(job #644363)

Utilizator CostinarflorinCostinar Florin Costinarflorin Data 6 decembrie 2011 10:33:00
Problema Parcurgere DFS - componente conexe Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.89 kb
#include <fstream>
#include <iostream>
using namespace std;

int n, m, ni, a[1000][1000], v[1000],gr=0;
ifstream fi ("dfs.in");
ofstream fo ("dfs.out");

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

}


int main() {
  int i, l, c;

  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] = a[c][l] = 1;
  }// Se actualizeaza matricea de adiacenta/
  // Se citeste nodul initial
  // Se marcheaza nodul initial ca fiind vizitat.
  for (i = 1; i <= n; i++)
  DFS(i);
  fo<<gr;
}