Cod sursa(job #2571736)

Utilizator DariusDCDarius Capolna DariusDC Data 5 martie 2020 09:51:20
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.65 kb
#include <bits/stdc++.h>

using namespace std;

ifstream fin("sortaret.in");
ofstream fout("sortaret.out");

int n, m;
vector <int> g[50005];
stack <int> st;
int viz[50005];

inline void dfs(int nod)
{
    viz[nod] = 1;
    for (auto fiu : g[nod])
    {
        if (viz[fiu])
            continue;
        dfs(fiu);
    }
    st.push(nod);
}

int main()
{
    fin >> n >> m;
    while (m--)
    {
        int a, b;
        fin >> a >> b;
        g[a].push_back(b);
    }
    for (int i = 1; i <= n; i++)
        if (!viz[i])
            dfs(i);
    while (!st.empty())
        fout << st.top() << " ", st.pop();
    return 0;
}