Pagini recente » Istoria paginii runda/123456789101112 | Istoria paginii runda/oji2020 | Cod sursa (job #2789475) | Cod sursa (job #1205550) | Cod sursa (job #2837837)
#include <iostream>
#include <vector>
const constexpr int N = 1e5+3;
int n, m;
std::vector<int> v[N];
bool vizitat[N];
/* DFS
*
* Marchezi nod curent ca fiind vizitat
* Fac DFS pt toti vecinii nevizitati
*
*/
void citire() {
std::cin >> n >> m;
for (auto i = 1; i <= m; i++) {
int x, y;
std::cin >> x >> y;
v[x].push_back(y);
v[y].push_back(x);
}
}
void dfs(int pos) {
vizitat[pos] = true;
for (auto it : v[pos]) {
if (!vizitat[it]) {
dfs(it);
}
}
}
int main(int argc, char** argv) {
freopen("dfs.in", "r", stdin);
freopen("dfs.out", "w", stdout);
citire();
int c = 0;
for (int i = 1; i <= n; i++) {
if (!vizitat[i]) {
dfs(i);
++c;
}
}
printf("%i", c);
return 0;
}