Cod sursa(job #1645810)

Utilizator andrew_assassin789Andrei Manea andrew_assassin789 Data 10 martie 2016 13:53:00
Problema Sortare topologica Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.95 kb
#include <fstream>
#include <list>
#include <stack>
#define w 50001
using namespace std;
list <unsigned int> a[w];
list <unsigned int> l;
stack <unsigned int> st;
unsigned short nrm[w];
void solve()
{
    list <unsigned int>::iterator it;
    int x;
    while (!st.empty())
    {
        x=st.top();
        l.push_back(x);
        st.pop();
        for (it=a[x].begin();it!=a[x].end();it++)
        {
            nrm[*it]--;
            if (!nrm[*it]) st.push(*it);
        }
        a[x].clear();
    }
}
int main()
{
    ifstream f("sortaret.in");
    ofstream g("sortaret.out");
    unsigned int i,x,y,n,m;
    f>>n>>m;
    for (i=1;i<=m;i++)
    {
        f>>x>>y;
        a[x].push_back(y);
        nrm[y]++;
    }
    for (i=1;i<=n;i++) if (!nrm[i])st.push(i);
    solve();
    for (list<unsigned int>::iterator it=l.begin();it!=l.end();it++) g<<*it<<' ';
    g<<'\n';
    f.close();
    g.close();
    return 0;
}