Cod sursa(job #1437638)

Utilizator GinguIonutGinguIonut GinguIonut Data 18 mai 2015 09:00:58
Problema Sortare topologica Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.7 kb
#include <fstream>
#define dim 50001
#include <vector>
using namespace std;
ifstream fin("sortaret.in");
ofstream fout("sortaret.out");
vector <int> G[dim];
int Q[dim],deg[dim],a,b,i,n,m,x;
int main()
{
    fin>>n>>m;
    for(i=1;i<=m;i++)
    {
        fin>>a>>b;
        G[a].push_back(b);
        deg[b]++;
    }
    for(i=1;i<=n;i++)
        if(deg[i]==0)
            Q[++Q[0]]=i;
    vector<int>::iterator it;
    for(i=1;i<=n;i++)
    {

        x=Q[i];
        for(it=G[x].begin();it!=G[x].end();it++)
        {
            deg[*it]--;
            if(deg[*it]==0)
                Q[++Q[0]]=*it;
        }
    }
    for(i=1;i<=n;i++)
        fout<<Q[i]<<" ";
    return 0;
}