Cod sursa(job #2437317)

Utilizator Groza_Iulia_DianaGroza Iulia Diana Groza_Iulia_Diana Data 9 iulie 2019 12:19:49
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.63 kb
#include <bits/stdc++.h>

using namespace std;
ifstream fin("sortaret.in");
ofstream fout("sortaret.out");

bool ok[50005];
int n, m, k, x, y, ts[50005];
vector<int> v[50005];

void dfs(int x)
{
    ok[x]=1;
    vector <int> :: iterator it;
    for(it=v[x].begin(); it<v[x].end(); it++)
        if(!ok[*it])
            dfs(*it);
    ts[++k]=x;
}

int main()
{
    fin >> n >> m;
    for(int i=1; i<=m; i++)
    {
        fin >> x >> y;
        v[x].push_back(y);
    }
    for(int i=1; i<=n; i++)
        if(!ok[i])
            dfs(i);
    for(int i=n; i>=1; i--)
        fout << ts[i] << " ";
    return 0;
}