Cod sursa(job #2747845)

Utilizator rARES_4Popa Rares rARES_4 Data 29 aprilie 2021 18:09:08
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.99 kb
#include<iostream>
#include <fstream>
#include <vector>
#include <queue>
#include <stack>
using namespace std;
ifstream f ("sortaret.in");
ofstream g ("sortaret.out");
int n,m;
vector<int>adiacenta[50001];
stack<int>rasp;
bool viz[50001];
void DFS(int nod)
{
    for(auto v:adiacenta[nod])
    {
        if(!viz[v])
        {
            viz[v] = 1;
            DFS(v);
        }
    }
    // cand nu mai avem unde sa mergem intr un nod il bagam intr-un stack pentru afisa raspunsurile invers
    rasp.push(nod);
}
int main()
{
    f >> n >> m;
    for(int i = 1;i<=m;i++)
    {
        int x,y;
        f >> x >> y;
        adiacenta[x].push_back(y);
    }
    for(int i = 1;i<=n;i++)
    {
        if(!viz[i])
        {
            // facem o parcurgere de la fiecare nod nevizitat
            viz[i] = 1;
            DFS(i);
        }
    }
    // afisam raspunsurile
    while(!rasp.empty())
    {
        g << rasp.top()<< " ";
        rasp.pop();
    }

}