Cod sursa(job #941104)

Utilizator rares96cheseliRares Cheseli rares96cheseli Data 17 aprilie 2013 22:38:01
Problema Parcurgere DFS - componente conexe Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.61 kb
#include <fstream>
#include <vector>
#define pb push_back

using namespace std;

ifstream f("dfs.in");
ofstream g("dfs.out");

int n,m,sol=0;
bool viz[100005];
vector < int > a[100005];

void dfs(int nod)
{
    viz[nod]=1;
    for (int i=1; i<=a[x].size; i++)
      if (viz[a[x][i]]==0) dfs(a[x][i]);
}

int main()
{
    f>>n>>m;
    for (int i=1; i<=m; i++)
    {
        int x,y;
        f>>x>y;
        a[x].pb(y); a[y].pb(x);
    }

    for (int i=1; i<=n; i++)
      if (viz[i]==0)
      {
          dfs(i); ++sol;
      }

    g<<sol<<'\n';
    f.close(); g.close();
    return 0;
}