Cod sursa(job #2110624)

Utilizator sebistetuCucolas Sebastian sebistetu Data 20 ianuarie 2018 23:10:09
Problema Sortare topologica Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.73 kb
#include<fstream>
#include<list>
#include<stack>
using namespace std;
ifstream f("sortaret.in");
ofstream g("sortaret.out");
const int Nmax = 50005;
list<int>l[Nmax];
stack<int>s;
bool viz[Nmax];
int n, m;
void citire(){
    f >> n >> m;
    int x, y;
    while(f >> x >> y)
        l[x].push_back(y);
}
void dfs(int nc){
    viz[nc] = true;
    list<int>::iterator it;
    for(it = l[nc].begin(); it != l[nc].end(); it++)
        if(!viz[*it])
            dfs(*it);
    s.push(nc);
}
void afisare(){
    while(!s.empty()){
        g << s.top() << ' ';
        s.pop();
    }
}
int main(){
    citire();
    for(int i = 1; i <= n; i++)
        if(!viz[i])
            dfs(i);
    afisare();
    return 0;
}