Cod sursa(job #2666641)

Utilizator KPP17Popescu Paul KPP17 Data 2 noiembrie 2020 11:44:52
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.65 kb
#define fisier "sortaret"
#include <fstream>
std::ifstream in(fisier ".in");
std::ofstream out(fisier ".out");
const int N = 50000;
#include <vector>
std::vector<int> L[N];
int R[N], l;
#include <bitset>
std::bitset<N> E;
int dfs(int t)
{
    E[t] = true;
    for (int f: L[t])
        if (not E[f])
            dfs(f);
    R[l++] = t;
}
int main()
{
    int n, m;
    in >> n >> m;
    while (m--)
    {
        int a, b;
        in >> a >> b;
        L[--a].push_back(--b);
    }
    for (int i = 0; i < n; i++)
        if (not E[i])
            dfs(i);
    for (int i = n - 1; i >= 0; i--)
        out << R[i] + 1 << ' ';
}