Cod sursa(job #2311870)

Utilizator rexlcdTenea Mihai rexlcd Data 3 ianuarie 2019 19:55:19
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.67 kb
#include <iostream>
#include <fstream>
#include <vector>

using namespace std;

vector < int > v[50002],sol;
bool mark[50002];

void dfs(int nod)
{
    if(mark[nod])
        return;
    for(int i=0;i<v[nod].size();i++)
        dfs(v[nod][i]);
    sol.push_back(nod);
    mark[nod]=1;
}

int main()
{
    ifstream f("sortaret.in");
    ofstream g("sortaret.out");
    int n,m;
    f>>n>>m;
    for(int i=1;i<=m;i++)
    {
        int x,y; f>>x>>y;
        v[x].push_back(y);
    }
    for(int i=1;i<=n;i++)
        dfs(i);
    for(int i=sol.size()-1;i>=0;i--)
        g<<sol[i]<<" ";
    g<<'\n';
    f.close();
    g.close();
    return 0;
}