Pagini recente » Cod sursa (job #1148094) | Cod sursa (job #2630819) | Cod sursa (job #2921625) | Cod sursa (job #2273767) | Cod sursa (job #644422)
Cod sursa(job #644422)
#include <fstream>
#include <iostream>
using namespace std;
int n, m, ni, a[2000][2000], v[2000], cc;
void DFS (int nc) {
int i;
// Se afiseaza nodul curent.
for (i = 1;i <= n;i++)// pentru fiecare nod
if (a[nc][i] == 1 and v[i] == 0) {// 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("dfs.in");
ofstream fo("dfs.out");
fi >> n; fi >> m;// Se citeste numarul de noduri si numarul de muchii.
for (i = 1;i <= m;i++) {// Pentru fiecare muchie
fi >> l;fi >> c;// Se citesc informatiile despre o muchie.
a[l][c] = 1;a[c][l] = 1;
}
for (i = 1;i <= n;i++) {
// Se actualizeaza matricea de adiacenta/// Se citeste nodul initial
if (v[i] == 0) {
v[i] = 1;
cc++;// Se marcheaza nodul initial ca fiind vizitat.
DFS(i);
}
}
cout << cc;
}