Cod sursa(job #2667483)

Utilizator Andy_ANDYSlatinaru Andrei Alexandru Andy_ANDY Data 3 noiembrie 2020 15:15:56
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.79 kb
#include <bits/stdc++.h>
#include <random>
#define ll long long
#define int ll
using namespace std;
ifstream f ( "sortaret.in" );
ofstream g ( "sortaret.out" );

vector < int > G[50005];
int n,m,grad[50005];
vector < int > topo;
void toposort()
{
    queue < int > q;
    for(int i=1;i<=n;i++)
    {
        if(grad[i]==0) q.push(i);
    }
    while(q.size())
    {
        int nod=q.front();
        topo.push_back(nod);
        q.pop();
        for(int v:G[nod])
        {
            grad[v]--;
            if(grad[v]==0) q.push(v);
        }
    }
}

main()
{
    f>>n>>m;
    for(int i=1;i<=m;i++)
    {
        int a,b;
        f>>a>>b;
        G[a].push_back(b);
        grad[b]++;
    }
    toposort();
    for(int x:topo) g<<x<< ' ';
    return 0;
}