Pagini recente » Cod sursa (job #163484) | Cod sursa (job #711694) | Cod sursa (job #1307611) | Cod sursa (job #2534567) | Cod sursa (job #1141859)
#include <fstream>
#include <vector>
using namespace std;
ifstream f("dfs.in");
ofstream g("dfs.out");
std::vector < int > l[100010];
int i,n,m,x,y,v[100010],nc;
void dfs(int nod){
v[nod] = 1;
for(int i=0;i<l[nod].size();i++)
if(v[l[nod][i]] == 0)
dfs(l[nod][i]);
}
int main()
{
f >> n >> m;
for(i=1;i<=m;i++){
f >> x >> y;
l[x].push_back(y);
l[y].push_back(x);
}
for(i=1;i<=n;i++)
if(v[i] == 0){
nc++;
dfs(i);
}
g<<nc;
return 0;
}