Pagini recente » Cod sursa (job #213163) | Cod sursa (job #643637) | Cod sursa (job #2678803) | Cod sursa (job #2897463) | Cod sursa (job #1128836)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("dfs.in");
ofstream g("dfs.out");
int n,i,m;
int a[20000][20000];
int vizitat[20000];
int nr_comp;
void dfs(int X)
{
vizitat[X]=1;
int i;
for(i=1; i<=n; i++)
if (a[X][i]==1)
if(vizitat[i]==0)
dfs(i);
}
int main()
{
f>>n>>m;
for(i=1; i<=n; i++)
{
int x,y;
f>>x>>y;
a[x][y]=a[y][x]=1;
}
for(i=1; i<=n; i++)
if(vizitat[i]==0)
{
nr_comp++;
dfs(i);
}
g<<nr_comp;
return 0;
}