Pagini recente » Cod sursa (job #638513) | Monitorul de evaluare | Istoria paginii utilizator/48kgkidsolica | Monitorul de evaluare | Cod sursa (job #3287776)
#include <iostream>
#include <fstream>
using namespace std;
const int MAXN = 100005;
int** adiacenta; // Tablou bidimensional alocat dinamic
int grad[MAXN];
void dfs(int nod, bool vizitat[]) {
vizitat[nod] = true;
for (int i = 0; i < grad[nod]; i++) {
int vecin = adiacenta[nod][i];
if (!vizitat[vecin]) {
dfs(vecin, vizitat);
}
}
}
int main() {
ifstream fin("dfs.in");
ofstream fout("dfs.out");
int n, m;
fin >> n >> m;
// Alocare dinamica pentru adiacenta
adiacenta = new int*[n + 1];
for (int i = 1; i <= n; i++) {
adiacenta[i] = new int[n + 1]; // Alocare initiala, se poate mari dinamic daca e nevoie
grad[i] = 0;
}
// Citire muchii
for (int i = 0; i < m; i++) {
int u, v;
fin >> u >> v;
adiacenta[u][grad[u]++] = v;
adiacenta[v][grad[v]++] = u; // Graf neorientat
}
// Initializare vector vizitat
bool vizitat[MAXN];
for (int i = 1; i <= n; i++) {
vizitat[i] = false;
}
int componenteConexe = 0;
for (int i = 1; i <= n; i++) {
if (!vizitat[i]) {
dfs(i, vizitat);
componenteConexe++;
}
}
fout << componenteConexe << endl;
// Eliberare memorie
for (int i = 1; i <= n; i++) {
delete[] adiacenta[i];
}
delete[] adiacenta;
fin.close();
fout.close();
return 0;
}