Cod sursa(job #2751562)

Utilizator mitocaru_marioMitocaru Mario-Alexandru mitocaru_mario Data 15 mai 2021 11:04:47
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.64 kb
#include <bits/stdc++.h>

using namespace std;
ifstream f("sortaret.in");
ofstream g("sortaret.out");
const int N=50002;
int n,m,gi[N],s[N];
vector<int> v[N];
int main()
{
    f>>n>>m;
    for(;m;m--)
    {
        int i,j;
        f>>i>>j;
        v[i].push_back(j);
        gi[j]++;
    }
    int p=1,u=0;
    for(int i=1;i<=n;i++)
        if(gi[i]==0)
            s[++u]=i;
    while(p<=u)
    {
        int nod=s[p++];
        for(auto vec:v[nod])
        {
            gi[vec]--;
            if(gi[vec]==0)
                s[++u]=vec;
        }
    }
    for(int i=1;i<=n;i++)
        g<<s[i]<<' ';
    return 0;
}