Cod sursa(job #2360085)

Utilizator VNohaiNohai Vlad-Auras VNohai Data 1 martie 2019 12:37:20
Problema Sortare topologica Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.79 kb
#include <iostream>
#include <vector>
#include <queue>
#include <fstream>
#include <queue>
#include <algorithm>
using namespace std;

#define NMAX 500005

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

int n, m;

queue <int> sol;
bool b[NMAX];
queue <int> q[NMAX];

void top(int poz)
{
    b[poz]=true;
    sol.push(poz);
    while(!q[poz].empty())
    {
    //sol.push(poz);
    if(b[poz])
    top(q[poz].front());
    q[poz].pop();
    }
}

void citire()
{
    fin>>n>>m;
    for(int i=1; i<=m; i++)
    {
    int x, y;
    fin>>x>>y;
    q[x].push(y);
    }
}

int main()
{
    citire();
    for(int i=1; i<=n; i++)
    if(!b[i])
    top(i);
    while(!sol.empty())
    {
    fout<<sol.front()<<" ";
    sol.pop();
    }
    return 0;
}