Cod sursa(job #3213272)

Utilizator Simon2712Simon Slanina Simon2712 Data 12 martie 2024 20:19:44
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.78 kb
#include <bits/stdc++.h>

using namespace std;
ifstream fin("sortaret.in");
ofstream fout("sortaret.out");
const int N=5e4+1;
vector<int> a[N];
int viz[N];
int l;
int v[N];
void f(int nod)
{
    if(viz[nod]==1) ///graful are un ciclu
        fout<<"NUH UH";
    else
    if(viz[nod]==0)
    {
        viz[nod]=1;
        int k=a[nod].size();
        for(int i=0;i<k;i++)
            f(a[nod][i]);
        viz[nod]=2;
        l--;
        v[l]=nod;
    }
}
int main()
{
    int n,m,i,x,y;
    fin>>n>>m;
    for(i=1;i<=m;i++)
    {
        fin>>x>>y;
        a[x].push_back(y);
    }
    l=n+1;
    for(i=1;i<=n;i++)
    {
        if(viz[i]==0)
        {
            f(i);
        }
    }
    for(i=1;i<=n;i++)
        fout<<v[i]<<" ";
    return 0;
}