Pagini recente » Cod sursa (job #2735447) | Cod sursa (job #2447075) | Cod sursa (job #3157708) | Cod sursa (job #1164833) | Cod sursa (job #1109403)
#include <fstream>
#include <vector>
using namespace std;
ifstream fin ("dfs.in");
ofstream fout ("dfs.out");
const int nmax = 100002;
vector <int> a[nmax];
bool viz[nmax];
int n,m,x,y,sol;
void df (int k)
{
viz[k]=1;
for (int i=1;i<=(int)a[k].size();++i)
{
if (viz[ a[k][i] ] == 0)
df (i);
}
}
int main ()
{
fin>>n>>m;
for (int i=1;i<=m;i++)
{
fin>>x>>y;
a[x].push_back( y );
a[y].push_back( x );
}
for (int j=1;j<=n;j++) {
if (viz[j]==0)
{ df (j);
++sol;} }
fout<<sol<<" ";
fin.close();
fout.close();
return 0;
}