Mai intai trebuie sa te autentifici.

Cod sursa(job #657079)

Utilizator caramete_tCaramete Tiberiu caramete_t Data 5 ianuarie 2012 19:03:27
Problema Parcurgere DFS - componente conexe Scor 40
Compilator cpp Status done
Runda Arhiva educationala Marime 0.54 kb
#include<fstream>
#include <stdio.h>
using namespace std;
int n,m,i,k=0,v[100005],c,h;
typedef struct nod
{int a;
nod *b;} *NOD;
NOD v1[100005];
void put(int q,NOD &go)
{NOD z;
z=new nod;
z->a=q;
z->b=go;
go=z;}
void df(int l)
{NOD p;
v[l]=1;
for(p=v1[l];p!=NULL;p=p->b) 
if(v[p->a]==0) 
df(p->a);}	
int main()
{ifstream f("dfs.in");
ofstream g("dfs.out");
f>>n;
f>>m;
for(i=0;i<m;i++)
{f>>c;
f>>h;
put(h,v1[c]);
put(c,v1[h]);}
f.close();
for(i=0;i<n;i++)
if(v[i]==0) 
{k++; 
df(i);}
g<<k;
g.close();
return 0;
}