Mai intai trebuie sa te autentifici.
Cod sursa(job #644363)
Utilizator | 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;
}