Cod sursa(job #2120693)

Utilizator usureluflorianUsurelu Florian-Robert usureluflorian Data 2 februarie 2018 19:34:44
Problema Sortare topologica Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.79 kb
#include <fstream>
#include <map>
#include <vector>
using namespace std;
ifstream f ("sortaret.in");
ofstream g ("sortaret.out");
const int nmax=5e4+3;
map <int,int> viz[nmax];
int n,m,a,b,grad[nmax],sol[nmax],k,nod;
vector <int> v[nmax];
int main()
{
    f>>n>>m;
    while(m--)
    {
          f>>a>>b;
          ++viz[a][b];
          if(viz[a][b]==1)
          {
                v[a].push_back(b);
                ++grad[b];
          }
    }
    for(int i=1;i<=n;++i) if(!grad[i]) sol[++k]=i;
    for(int i=1;i<=k;++i)
    {
          nod=sol[i];
          for(int j=0;j<v[nod].size();++j)
          {
                --grad[v[nod][j]];
                if(!grad[v[nod][j]]) sol[++k]=v[nod][j];
          }
    }
    for(int i=1;i<=n;++i) g<<sol[i]<<' ';
    return 0;
}