Pagini recente » Cod sursa (job #1581136) | Borderou de evaluare (job #1567200) | Cod sursa (job #968651) | Cod sursa (job #310754) | Cod sursa (job #644366)
Cod sursa(job #644366)
#include <fstream>
using namespace std;
int nc, n, m, ni, a[2000][2000], v[2000];
void DF (int nc) {
int i;
for (i = 1; i <= n; i++) // pentru fiecare nod
if (a[nc][i] && !v[i]) { // i este vecin nevizitat al nodului curent?
v[i] = 1; // Marcam i ca fiind vizitat.
DF(i); // Continuam parcurgerea in adancime.
}
}
int main() {
int i, x, y;
ifstream fi("dfs.in");
ofstream fo("dfs.out");
fi >> n >> m;
for (i = 1; i <= m; i++) {
fi >> x >> y;
a[x][y] = a[y][x] = 1;
}
for (ni = 1; ni <= n; ni++)
if (!v[ni]) {
v[ni] = 1;
DF(ni);
nc++;
}
fo << nc;
}