Cod sursa(job #3250896)

Utilizator mihai_irdIordache Mihai mihai_ird Data 24 octombrie 2024 09:01:26
Problema Parcurgere DFS - componente conexe Scor 50
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.69 kb
#include <fstream>
#include <list>
#include <algorithm>
using namespace std;
ifstream cin("dfs.in");
ofstream cout("dfs.out");
list<int>x[100001];
int v[100001],nr;
void dfs(int a,int n){
    v[a]=1;
    for(int i=1;i<=n;i++){
        if(!v[i]){
             auto it = std::find(x[a].begin(), x[a].end(), i);
             if(it!=x[a].end())
                dfs(i,n);
        }
    }
}
int main()
{
    int n,m,a,b;
    cin>>n>>m;
    for(int i=1;i<=m;i++){
        cin>>a>>b;
       x[a].push_back(b);
       x[b].push_back(a);
    }
    for(int i=1;i<=n;i++)
        if(!v[i])
        {
           dfs(i,n);
           nr++;
        }
    cout<<nr;
    return 0;
}