Cod sursa(job #2373950)

Utilizator VNohaiNohai Vlad-Auras VNohai Data 7 martie 2019 16:07:28
Problema Sortare topologica Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.78 kb
#include <iostream>
#include <vector>
#include <queue>
#include <fstream>
#include <queue>
#include <algorithm>
using namespace std;

#define NMAX 50005

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

int n, m;

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

void top(int poz)
{
    b[poz]=true;
    sol.push_back(poz);
    for(int i=0; i<q[poz].size(); i++)
    {
    //sol.push(poz);
    if(b[poz])
    top(q[poz][i]);
    }
}

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

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