Cod sursa(job #3296202)

Utilizator Traian_7109Traian Mihai Danciu Traian_7109 Data 12 mai 2025 10:04:01
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.68 kb
#include <fstream>
#include <vector>

using namespace std;

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

const int MAXN = 50000;

vector<int> g[MAXN + 1], order;
int viz[MAXN + 1];

void dfs(int node) {
  viz[node] = 1;
  for(int vecin : g[node]) {
    if(!viz[vecin]) {
      dfs(vecin);
    }
  }
  order.push_back(node);
}

int main() {
  int n, m;
  fin >> n >> m;
  for(int i = 1; i <= m; i++) {
    int u, v;
    fin >> u >> v;
    g[u].push_back(v);
  }

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

  for(int i = n - 1; i >= 0; i--) {
    fout << order[i] << " ";
  }
  fout << "\n";
  return 0;
}