Cod sursa(job #1229403)

Utilizator ducu34Albastroiu Radu Gabriel ducu34 Data 17 septembrie 2014 08:55:36
Problema Parcurgere DFS - componente conexe Scor 45
Compilator cpp Status done
Runda Arhiva educationala Marime 0.6 kb
#include <fstream>
using namespace std;
ifstream fin("dfs.in");
ofstream fout("dfs.out");
int a[1000][1000],x,y,n,m,i,OK,zi,viz[10000];
void dfs(int k)
{
    int i=0;
    viz[k]=zi;
    for(i=1;i<=n;i++)
    if(a[k][i] && !viz[i])
    {
        dfs(i);
    }
}
int main()
{
   fin>>n>>m;
   for(i=1;i<=m;i++)
   {
       fin>>x>>y;
       a[x][y]=a[y][x]=1;
   }
   zi=1;
   dfs(1);
   OK=1;
   while(OK)
   {
       OK=0;
       for(i=1;i<=n;i++)
       if(!viz[i])
       {
           OK=1;
           zi++;
           dfs(i);
           break;
       }
   }
   fout<<zi;
}