Pagini recente » Cod sursa (job #2902383) | Cod sursa (job #2352709) | Cod sursa (job #139128) | Cod sursa (job #2166751) | Cod sursa (job #786183)
Cod sursa(job #786183)
#include <fstream>
using namespace std;
int n, m, ni, a[2000][2000], v[2000], nr;
ifstream fi("df2.in");
ofstream fo("df2.out");
void DFS (int nc) {
int i;
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.
fo << i << ' ';
DFS(i);// 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] = 1; a[c][l] = 1;// Se actualizeaza matricea de adiacenta.
}
for (i = 1; i <= n; i++) {
if (v[i] == 0) {
v[i] = 1;
nr++;
DFS(i);
}
}
fo << nr;
}
// 1 2 5
// 3 4 6