Cod sursa(job #3292210)

Utilizator Mihai.OnofreiOnofrei Mihai Mihai.Onofrei Data 7 aprilie 2025 15:27:38
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.66 kb
#include <bits/stdc++.h>
#define nmax 50002
using namespace std;
ifstream f("sortaret.in");
ofstream g("sortaret.out");
int n,m,dr,d[nmax],Q[nmax];
vector <int> L[nmax];
int main()
{   f>>n>>m;
    for(int a,b; m; m--)
        {f>>a>>b; L[a].push_back(b); d[b]++; }
    for(int i=1; i<=n; i++)
        if(d[i]==0) Q[++dr]=i;
    int st=1;
    while(st<=dr)
    {   int x=Q[st];
        vector <int> :: iterator it=L[x].begin(),sf=L[x].end();
        for(; it!=sf; it++)
        {   d[*it]--;
            if(d[*it]==0) Q[++dr]=*it;
        }
        st++;
    }
    for(int i=1; i<=dr; i++) g<<Q[i]<<' ';
    g.close();
    f.close();
    return 0;
}