Cod sursa(job #2406817)

Utilizator alexalghisiAlghisi Alessandro Paolo alexalghisi Data 16 aprilie 2019 11:26:08
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.67 kb

#include <fstream>
#include <vector>

#define DN 50005
using namespace std;

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

vector<int> lst[DN], rez;
bool viz[DN];

void dfs(int nod) {
    viz[nod] = true;
    for(vector<int>::iterator it=lst[nod].begin();it!=lst[nod].end();++it) {
        if(!viz[*it]) {
            dfs(*it);
        }
    }
    rez.push_back(nod);
}

int main() {
    int n, m;
    f>>n>>m;

    for(int a,b;m--;) {
        f>>a>>b;
        lst[a].push_back(b);
    }

    for(int i=1;i<=n;++i) {
        if(!viz[i])
            dfs(i);
    }

    for(int i=n-1;i>=0;--i)
        g<<rez[i]<<" ";
    return 0;
}