Cod sursa(job #2574765)

Utilizator LeperBearMicu Alexandru LeperBear Data 6 martie 2020 09:44:16
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.72 kb
#include <fstream>
#include <vector>
#define ios ios_base::sync_with_stdio(false);
#define Nmax 100005

using namespace std;

ifstream cin("dfs.in");
ofstream cout("dfs.out");

vector<int> g[Nmax];
int n,m,nr;
bool viz[Nmax];

void citire(){
    cin>>n>>m;
    for (int i=1;i<=m;i++){
        int x,y;
        cin>>x>>y;
        g[x].push_back(y);
        g[y].push_back(x);
    }
}

void DFS(int ns){
    viz[ns]=1;
    for (unsigned j=0;j<g[ns].size();j++){
        if (viz[g[ns][j]]==0) {viz[g[ns][j]]=1; DFS(g[ns][j]);}
    }
}

int main()
{
    ios;
    cin.tie(0);
    cout.tie(0);
    citire();
    int i;
    for (i=1;i<=n;i++) if(viz[i]==0){nr++; DFS(i);}
    cout<<nr;
    return 0;
}