Cod sursa(job #550943)

Utilizator alexapoApostol Alexandru Ionut alexapo Data 10 martie 2011 09:49:29
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.6 kb
# include <fstream.h>
ifstream f("dfs.in");
ofstream g("dfs.out");

struct nod{ int a; nod* urm;};
nod * v[100001],*p;
long i,m,n,x,y,nrc;
int viz[100001];// viz[i]=1=> am ajuns in i
void citire()
{
	f>>n>>m;
	for(i=1;i<=m;i++)
		{f>>x>>y; p=new nod; p->a=y; p->urm=v[x];v[x]=p;
		          p=new nod; p->a=x; p->urm=v[y];v[y]=p;
		}
}

void dfs(int x)
{ viz[x]=1;
  nod *p=v[x];
  while(p){ if(viz[p->a]==0) dfs(p->a);
            p=p->urm;}  
	
}


int main()
{
	citire();
	for(i=1;i<=n;i++) if(viz[i]==0){nrc++;dfs(i);}
	g<<nrc<<'\n';
	f.close();
	g.close();
	return 0;
}