Cod sursa(job #3198519)

Utilizator Info_MasterAugustin-Ionut Info_Master Data 29 ianuarie 2024 18:38:15
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.73 kb
#include <iostream>
#include <fstream>
#include <vector>
#include <algorithm>

using namespace std;

ifstream fin("dfs.in");
ofstream fout("dfs.out");

vector<vector<int>>graf;
bool vis[100005];

void DFS(int nod){
    vis[nod]=true;
    for(int vec: graf[nod]){
        if(!vis[vec]){
            DFS(vec);
        }
    }
}

int main()
{
    int n,m;
    fin>>n>>m;
    graf.resize(n+1);
    for(int i=0;i<m;i++){
        int nod1,nod2;
        fin>>nod1>>nod2;
        graf[nod1].push_back(nod2);
        graf[nod2].push_back(nod1);
    }
    int cont=0;
    for(int nod=1;nod<=n;nod++){
        if(!vis[nod]){
            cont++;
            DFS(nod);
        }
    }
    fout<<cont;

    return 0;
}