Pagini recente » Cod sursa (job #1821259) | Cod sursa (job #1779095) | Cod sursa (job #3141399) | Cod sursa (job #1989905) | Cod sursa (job #325584)
Cod sursa(job #325584)
#include <cstdio>
#include <cstdlib>
#define Nmax 100100
#define file_in "dfs.in"
#define file_out "dfs.out"
struct Nod
{
int inf;
struct Nod *urm;} *Lista[Nmax];
int n,m;
int viz[Nmax];
void add(int x, int y)
{
Nod *q=new Nod;
q->inf=y;
q->urm=Lista[x];
Lista[x]=q;
}
void dfs(int nod)
{
Nod *p;
viz[nod]=1;
for (p=Lista[nod];p;p=p->urm)
if (!viz[p->inf])
dfs(p->inf);
}
int main()
{
int i,x,y;
freopen(file_in,"r",stdin);
freopen(file_out,"w",stdout);
scanf("%d %d", &n,&m);
for (i=1;i<=m;++i)
{
scanf("%d %d", &x,&y);
add(x,y);
add(y,x);
}
int nr=0;
for (i=1;i<=n;++i)
if (!viz[i])
{
dfs(i);
nr++;
}
printf("%d", nr);
fclose(stdin);
fclose(stdout);
return 0;
}