Cod sursa(job #2218754)

Utilizator petru123456789Petru B petru123456789 Data 5 iulie 2018 16:51:13
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.95 kb
#include <bits/stdc++.h>

using namespace std;
vector<int> v[100001];
int n,m,x,y,s;
bool viz[100001];
void dfs(int q)
{
    viz[q]=1;
    //cout<<q<<' ';
    for(int i=0;i<v[q].size();i++)
    {
        int r=v[q][i];

        if(viz[r]==0)
        {
           // cout<<r<<' ';
            dfs(r);
        }
    }
   // cout<<'\n';
}
int main()
{
    int i;
    ifstream in("dfs.in");
    ofstream out("dfs.out");
    in>>n>>m;
    for(i=1;i<=m;i++)
    {
        in>>x>>y;
        v[x].push_back(y);
        v[y].push_back(x);
    }
    /*for(i=1;i<=n;i++)
    {
        for(j=0;j<v[i].size();j++)
        {
            cout<<v[i][j]<<' ';
        }
        cout<<'\n';
    }*/
    for(i=1;i<=n;i++)
    {
        if(viz[i]==0)
        {
            //cout<<i<<' ';
            dfs(i);
            s++;
        }
    }
    dfs(1);

    for (i=1;i<=n;++i) {
       // cout << viz[i] << ' ';
    }
    out<<s<<'\n';
}