Pagini recente » Cod sursa (job #858603) | Cod sursa (job #2038787) | Cod sursa (job #1027489) | Cod sursa (job #2473032) | Cod sursa (job #1268591)
#include <fstream>
using namespace std;
int n, m, cc, l, c, i; // noduri, muchii, componente conexe
bool a[2000][2000], v[2000];
ifstream fin("dfs.in");
ofstream fout("dfs.out");
void DFS (int nc) {
int i;
for (i = 1; i <= n; i++) // pentru fiecare nod
if (a[nc][i] and not v[i]) { // i este vecin nevizitat al nodului curent?
v[i] = true; // Marcam i ca fiind vizitat.
DFS(i); // Continuam parcurgerea in adancime.
}
}
int main() {
fin >> n >> m; // Se citeste numarul de noduri si numarul de muchii.
for (i = 1; i <= m; i++) { // Pentru fiecare muchie
fin >> l >> c; // Se citesc informatiile despre o muchie.
a[l][c] = a[c][l] = true; // Se actualizeaza matricea de adiacenta
}
for (i = 1; i <= n; i++) {
if (not v[i]) {
v[i] = 1;
cc++;
DFS(i);
}
}
fout << cc;
}