Pagini recente » Monitorul de evaluare | Cod sursa (job #399277) | Cod sursa (job #267537) | Cod sursa (job #1731176) | Cod sursa (job #932629)
Cod sursa(job #932629)
#include <iostream>
#include <fstream>
#include <cstring>
#include <vector>
#define nmax 100005
using namespace std;
vector <int> vecin[nmax];
bool vizitat[nmax];
void dfs(int curent) {
for(int i = 0; i < vecin[curent].size(); i++)
if(!vizitat[vecin[curent][i]]) {
vizitat[vecin[curent][i]] = true;
dfs(vecin[curent][i]);
}
}
int main() {
ifstream f("dfs.in");
ofstream g("dfs.out");
int n, m, i, j, a, b, sol = 0;
f>>n>>m;
for(i=1; i<=m; i++) {
f>>a>>b;
vecin[a].push_back(b);
vecin[b].push_back(a);
}
memset(vizitat, 0, nmax*sizeof(bool));
for(i=1; i<=n; i++)
if(!vizitat[i]) {
sol++;
dfs(i);
}
g<<sol<<"\n";
return 0;
}