Cod sursa(job #2030980)

Utilizator R.DavidDavid Rusu R.David Data 2 octombrie 2017 16:27:33
Problema Parcurgere DFS - componente conexe Scor 5
Compilator cpp Status done
Runda Arhiva educationala Marime 0.69 kb
#include<iostream>
#include<fstream>
#include<vector>
using namespace std;

void dfs(int);

ifstream input("dfs.in");
ofstream out("dfs.out");

int n,m,legaturi = 1;

vector<int> nds[100005];

int main()
{
    int i ,x ,y;

    input>>n>>m;

    for(i = 1; i <= m; i++)
    {
        input>>x>>y;
        nds[x].push_back(y);
    }

    for(i = 1; i <= n; i++)
    {
        dfs(i);
    }

    out<<legaturi;
}

void dfs(int node)
{
    for(int i = 0; i < nds[node].size(); i++)
    {
        if(nds[node][i] != -1)
        {
            int next = nds[node][i];
            nds[node][i] = -1;
            legaturi ++;
            dfs(next);
        }
    }
}