Cod sursa(job #644355)

Utilizator infomaster666Shalau Dumitru infomaster666 Data 6 decembrie 2011 10:17:13
Problema Parcurgere DFS - componente conexe Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.82 kb
#include <fstream>
#include <iostream>

using namespace std;

int n, m, a[50][50], v[50];
bool ni;

void DFS (int nc) {
  int i;

  cout << nc << ' ';// Se afiseaza nodul curent.
  for (i=1;i<=n;i++)// pentru fiecare nod
    if (v[i] = 0 and a[nc][i] =1)// 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 >> m;// Se citeste numarul de noduri si numarul de muchii.
  for (i=1;i<=m;i++){// Pentru fiecare muchie
    fi >> c >> l;// Se citesc informatiile despre o muchie.
    a[l][c] = a[c][l] = 1;// Se actualizeaza matricea de adiacenta
  }
  fi >> ni;// Se citeste nodul initial
  v[ni] = 1; // Se marcheaza nodul initial ca fiind vizitat.
  DFS(ni);

}