Pagini recente » Cod sursa (job #1449364) | Cod sursa (job #2426792) | Cod sursa (job #605486) | Cod sursa (job #2307463) | Cod sursa (job #2213217)
/*
Keep It Simple!
*/
#include <fstream>
#include <vector>
#include <stack>
using namespace std;
const int MAX_N = 50005;
int N, M;
int viz[MAX_N];
vector<int> G[MAX_N];
stack<int> Sol;
void ReadInput() {
ifstream f("sortaret.in");
f >> N >> M;
int x, y;
for (int i = 1; i <= M; ++i) {
f >> x >> y;
G[x].push_back(y);
}
}
void DFS(int node) {
viz[node] = 1;
for (auto son : G[node])
if (!viz[son])
DFS(son);
Sol.push(node);
}
void Solve() {
ReadInput();
for (int i = 1; i <= N; ++i)
if (!viz[i])
DFS(i);
ofstream g("sortaret.out");
while (Sol.size()) {
g << Sol.top() << " ";
Sol.pop();
}
g << '\n';
}
int main()
{
Solve();
return 0;
}