Cod sursa(job #1582858)

Utilizator SerbanR98Serban Raicu SerbanR98 Data 28 ianuarie 2016 16:00:29
Problema Sortare topologica Scor 60
Compilator cpp Status done
Runda Arhiva educationala Marime 0.63 kb
#include <fstream>
#include <vector>
#define pb push_back;
using namespace std;
ifstream f("sortaret.in");
ofstream g("sortaret.out");
vector <int> L[10001];
vector <int>::iterator it;
int n,m,x,y,st[10001],nr;
bool sel[10001];
void load()
{int i;
    f>>n>>m;
    for(i=1;i<=m;i++)
    {
        f>>x>>y;
        L[x].push_back(y);
    }
}


void df(int x)
{int i;
    sel[x]=true;

    for(i=0;i<L[x].size();i++)
    if(!sel[L[x][i]])
    {
        df(L[x][i]);
    }
    st[++nr]=x;
}

int main()
{
    int i;

    load();
    for(i=1;i<=n;i++) if(!sel[i]) df(i);
 for(i=n;i>=1;i--)
 g<<st[i]<<" ";

}