Pagini recente » Borderou de evaluare (job #2047682) | Borderou de evaluare (job #1448265) | Borderou de evaluare (job #2010747) | Borderou de evaluare (job #2576421) | Cod sursa (job #2095618)
#include <bits/stdc++.h>
#define NMAX 100000
using namespace std;
ifstream fi("dfs.in");
ofstream fo("dfs.out");
int n,m,rez;
int VIZ[NMAX+1];
vector <int> VECINI[NMAX+1];
void citire(void)
{
int x,y;
fi>>n>>m;
for(int i=1; i<=m; i++)
{
fi>>x>>y;
VECINI[x].push_back(y);
VECINI[y].push_back(x);
}
}
void DFS(int nod)
{
int nnod;
for(int i=0; i<VECINI[nod].size(); i++)
{
nnod=VECINI[nod][i];
if(!VIZ[nnod])
{
VIZ[nnod]=1;
DFS(nnod);
}
}
}
void rezolvare(void)
{
for(int i=1; i<=n; i++)
if(!VIZ[i])
{
rez++;
DFS(i);
}
}
inline void afisare(void)
{
fo<<rez;
}
int main()
{
citire();
rezolvare();
afisare();
fi.close();
fo.close();
return 0;
}