Cod sursa(job #1858537)

Utilizator miruna999Morarasu Miruna miruna999 Data 27 ianuarie 2017 15:32:54
Problema Sortare topologica Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.61 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("sortaret.in");
ofstream g("sortaret.out");
int n,m,a[50001][50001],x[50001],j,viz[50001];

void citire()
{
    f>>n>>m;
    int x1,x2;
    for(int i=1;i<=m;i++)
        f>>x1>>x2,a[x1][x2]=1;
}

void df(int k)
{
    for(int i=1;i<=n;i++)
        if(a[k][i]&&!viz[i])
        {
            a[k][i]=0;
            df(i);
        }
    x[++j]=k;viz[k]=1;
}

int main()
{
    citire();
    for(int i=1;i<=n;i++)
        if(viz[i]==0)
            df(i);
    for(int i=j;i>=1;i--)
        g<<x[i]<<" ";
    return 0;
}