Pagini recente » Cod sursa (job #3224735) | Cod sursa (job #2041855) | Cod sursa (job #2261571) | Cod sursa (job #723191) | Cod sursa (job #2439354)
#include <fstream>
#include <queue>
#include <vector>
using namespace std;
ifstream cin("sortaret.in");
ofstream cout("sortaret.out");
int n, m;
vector<int> g[50005];
int dep[50005];
int main() {
queue<int> nodep;
cin >> n >> m;
for (int i = 0; i < m; ++i) {
int a, b;
cin >> a >> b;
g[a].push_back(b);
dep[b]+= 1; }
for (int i = 1; i <= n; ++i) if (dep[i] == 0) {
nodep.push(i);
}
while (!nodep.empty()) {
int u = nodep.front();
nodep.pop();
cout << u << ' ';
for (int j = 0; j < g[u].size(); ++j) {
int v = g[u][j];
dep[v]-= 1;
if (!dep[v])
nodep.push(v);
}
}
return 0;
}