Cod sursa(job #1750311)

Utilizator matzul98Socaciu Mihai matzul98 Data 29 august 2016 21:28:17
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.92 kb
#include <iostream>
#include <fstream>
#include <vector>
using namespace std;
ifstream f("dfs.in");
ofstream g("dfs.out");
/*
6 3
1 2
1 4
3 5
*/

int n;
vector<int> V[100001];

void Citire()
{
   //Citirea vecinilor nodurilor
   int m;
   f>>n>>m;

   for(int i=0;i<m;i++)
   {
      int x,y;
      f>>x>>y;
      V[x].push_back(y);
      V[y].push_back(x);
   }
}

bool viz[100001] = {0};
void DFS(int start)
{
   //Parcurgere in inaltime
   viz[start]=true;

   for(int i=0; i < V[start].size(); i++)//Parcurgem vecinii lui start
   {
      if(!viz[V[start][i]])//Nu este vizitat -> il vizitam pe el si pe vecinii lui
      {
         DFS(V[start][i]);
      }
   }
}

int main()
{
   Citire();
   //NUMEROTARE DE LA 1 la n
   int nr=0;//Cate comp conexe?
   for(int i = 1; i <= n; i++)
   {
      if(!viz[i])
      {
         DFS(i);
         nr++;
      }
   }

   g<<nr;
}