Pagini recente » Cod sursa (job #1699489) | Cod sursa (job #120424) | Cod sursa (job #2930379) | Cod sursa (job #1680318) | Cod sursa (job #199427)
Cod sursa(job #199427)
using namespace std;
#include <iostream>
#include <fstream>
const int N=100005;
void df(int x,int n,int *a[N],bool viz[N])
{
viz[x]=true;
for(int i=1;i<=a[x][0];++i)
{
int y=a[x][i];
if(!viz[y])
df(y,n,a,viz);
}
}
int main()
{
int nr=0,n,m,i,*a[N],x,y;
int d[N]={0};
bool viz[N];
ifstream f("dfs.in");
ofstream g("dfs.out");
f>>n>>m;
for(i=1;i<=m;++i)
{
f>>x>>y;
++d[x];
++d[y];
//a[x][++a[x][0]]=y;
//a[y][++a[y][0]]=x;
}
f.close();
for(i=1;i<=n;++i){
viz[i]=false;
a[i]=new int[1+d[i]];
a[i][0]=0;
}
ifstream ff("dfs.in");
ff>>n>>m;
for(i=1;i<=m;++i)
{
ff>>x>>y;
a[x][++a[x][0]]=y;
a[y][++a[y][0]]=x;
}
for(i=1;i<=n;++i)
if(!viz[i]){
df(i,n,a,viz);
++nr;
}
g<<nr<<"\n";
ff.close();
g.close();
return 0;
}