Cod sursa(job #2487698)

Utilizator vladcociorvaVlad Cociorva vladcociorva Data 5 noiembrie 2019 18:04:11
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.61 kb
#include <bits/stdc++.h>
#define NMAX 100005
using namespace std;
ifstream fin("dfs.in");
ofstream fout("dfs.out");
bool vis[NMAX];
void dfs (int x, vector<vector<int>>& g)
{
  if (vis[x]) return;
  vis[x] = 1;
  for (auto u: g[x])
  {
    dfs(u, g);
  }
}
int main()
{
  ios::sync_with_stdio(false);
  cin.tie(0);
  int n, m;
  fin >> n >> m; 
  vector<vector<int>>g(n+1);
  for (int i = 1; i <= m; ++i)
  {
    int x, y;
    fin >> x >> y;
    g[x].push_back(y);
    g[y].push_back(x);
  }
  int ans = 0;
  for (int i = 1; i <= n; ++i)
  {
    if (!vis[i]){
      dfs(i, g);
      ans++;
    }
  }
  fout << ans << '\n';

}