Cod sursa(job #1807440)

Utilizator serbanSlincu Serban serban Data 16 noiembrie 2016 16:43:34
Problema Sortare topologica Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.76 kb
#include <fstream>
#include <vector>
#include <stack>

using namespace std;

vector<int> L[50005];
int c[50005];

stack<int> s;

int main()
{
    ifstream f("sortaret.in");
    ofstream g("sortaret.out");

    int n, m, x, y;
    f >> n >> m;
    for(int i = 1; i <= m; i ++) {
        f >> x >> y;
        L[x].push_back(y);
        c[y] ++;
    }

    for(int i = 1; i <= n; i ++) {
        if(c[i] == 0) {
            s.push(i);
        }
    }

    for(int i = 1; i <= n; i ++) {
        int k = s.top();
        g << k << " ";
        s.pop();
        for(int j = 0; j < L[k].size(); j ++) {
            c[L[k][j]] --;
            if(c[L[k][j]] == 0)
                s.push(L[k][j]);
        }
    }
    g << "\n";
    return 0;
}