Cod sursa(job #3242668)

Utilizator Alexandru_cioAlexandru Ciobanica Alexandru_cio Data 13 septembrie 2024 08:32:29
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.68 kb
#include <bits/stdc++.h>

using namespace std;

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

const int NMAX=1e5;
vector<int> G[NMAX+1];
int vis[NMAX+1];

void dfs(int node)
{
    vis[node]=1;
    for(int i=0;i<G[node].size();i++)
    {
        int vecin=G[node][i];
        if(vis[vecin]==0)
            dfs(vecin);
    }
}

int main()
{
    int n,m;
    f>>n>>m;
    int nrcc=0;
    for(int i=1;i<=m;i++)
    {
        int x,y;
        f>>x>>y;
        G[x].push_back(y);
        G[y].push_back(x);
    }
    for(int i=1;i<=n;i++)
    {
        if(vis[i]==0)
        {
            nrcc++;
            dfs(i);
        }
    }
    g<<nrcc;
    return 0;
}