Cod sursa(job #2782509)

Utilizator icnsrNicula Ionut icnsr Data 12 octombrie 2021 16:04:16
Problema Parcurgere DFS - componente conexe Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.88 kb
#include <cstdio>
#include <vector>

void DFS(auto& visited, auto& list, int start)
{
        visited[start] = true;

        for(int v : list[start])
        {
                if(!visited[v])
                {
                        DFS(visited, list, v);
                }
        }
}

int main()
{
        int n, m;
        std::scanf("%d%d", &n, &m);

        std::vector<std::vector<int>> list(n + 1);
        std::vector<char> visited(n + 1, false);
        for(int i = 0; i < m; ++i)
        {
                int x, y;
                std::scanf("%d%d", &x, &y);

                list[x].push_back(y);
        }

        int res = 0;
        for(int node = 1; node <= n; ++node)
        {
                if(!visited[node])
                {
                        ++res;
                        DFS(visited, list, node);
                }
        }

        std::printf("%d\n", res);
}