Cod sursa(job #2518401)

Utilizator TocuAndreiTocu Andrei TocuAndrei Data 5 ianuarie 2020 17:41:13
Problema Sortare topologica Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.88 kb
#include <iostream>
#include <vector>
#include <fstream>
using namespace std;
ifstream fin("sortaret.in");
ofstream fout("sortaret.out");
int const nLim = 50005;
vector < int > Arce[nLim];
bool vizitat[nLim];
int n, m;
int sortare[nLim], indiceSort = 0;

void DFS(int i) {
    vizitat[i] = true;
    for(unsigned int j = 0; j < Arce[i].size(); j ++) {
        int next = Arce[i][j];
        if(!vizitat[next]) {
            DFS(next);
        }
    }
    sortare[++indiceSort] = Arce[i];
}

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

    for(int i = 1; i <= n; i ++) {
        if(!vizitat[i])
            DFS(i);
    }

    for(int i = indiceSort; i >= 1; i --){
        fout << sortare[i] << " ";
    }
}

int main() {
    citire();
    return 0;
}