Pagini recente » Cod sursa (job #1447552) | Cod sursa (job #1505892) | Cod sursa (job #1816504) | Cod sursa (job #2855229) | Cod sursa (job #1814143)
#include <cstdio>
#include <queue>
using namespace std;
struct graf{int v,m,adi[1000][1000];};
graf A;
queue<int> q;
int viz[1000];
void Read()
{
int a,b;
freopen("dfs.in","r",stdin);
freopen("dfs.out","w",stdout);
scanf("%i %i",&A.v,&A.m);
for(int i=1;i<=A.v;i++)
{
for(int j=1;j<=A.v;j++)
{
scanf("%i %i",&a,&b);
A.adi[a][b]=A.adi[b][a]=1;
}
}
}
void Parcurgere(int nod,int k)
{
q.push(nod);
viz[nod]=k;
while(!q.empty())
{
for(int i=1;i<=A.v;i++)
{
if((A.adi[q.front()][i] == 1) && (viz[i]==0))
{
viz[i]=k;
q.push(i);
}
}
q.pop();
}
}
int main()
{
int k=1;
Read();
for(int i=1;i<=A.v;i++)
viz[i]=0;
for(int i=1;i<=A.v;i++)
if(viz[i]==0)
Parcurgere(i,++k);
printf("%i",--k);
return 0;
}