Pagini recente » Cod sursa (job #282870) | Cod sursa (job #2924761) | Cod sursa (job #2515246) | Cod sursa (job #2027739) | Cod sursa (job #944961)
Cod sursa(job #944961)
#include <iostream>
#include <fstream>
#include <algorithm>
#include <vector>
using namespace std;
#define ech(It, A) for (__typeof(A.begin()) It = A.begin(); It != A.end(); ++It)
vector<vector<int> > adjl;
vector<int> component;
int color = 1;
void dfs(int idx) {
component[idx] = color;
ech(it, adjl[idx]) {
if (component[*it] == 0)
dfs(*it);
}
}
int main() {
ifstream fin("dfs.in");
ofstream fout("dfs.out");
int n, m;
fin >> n >> m;
adjl.resize(n+1);
component.resize(n+1);
for (int i = 0; i < m; ++i) {
int u, v;
fin >> u >> v;
adjl[u].push_back(v);
adjl[v].push_back(u);
}
for (int i = 1; i <= n; ++i) {
if (component[i] == 0) {
dfs(i);
++color;
}
}
fout << color-1;
return 0;
}