Pagini recente » Cod sursa (job #1318795) | Cod sursa (job #801093) | Cod sursa (job #1849828) | Cod sursa (job #1609182) | Cod sursa (job #2439351)
#include <fstream>
#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() {
vector<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_back(i);
}
while (!nodep.empty()) {
int u = nodep.back();
nodep.pop_back();
cout << u << ' ';
for (int j = 0; j < g[u].size(); ++j) {
int v = g[u][j];
dep[v]-= 1;
if (!dep[v])
nodep.push_back(v);
}
}
return 0;
}