Pagini recente » Cod sursa (job #2307840) | Cod sursa (job #335677) | Cod sursa (job #542413) | Cod sursa (job #1320366) | Cod sursa (job #2940725)
#include <bits/stdc++.h>
using namespace std;
ifstream in("sortaret.in");
ofstream out("sortaret.out");
int n, m, st[50005], top;
vector <int> a[50005];
bitset <50005> viz;
///O(n + m)
void Dfs(int x)
{
viz[x] = 1;
for (int w : a[x])
if (viz[w] == 0)
Dfs(w);
st[++top] = x;
}
int main()
{
int i , x , y;
in >> n >> m;
for (i = 1; i <= m; i++)
{
in >> x >> y;
a[x].push_back(y);
}
for (i = 1; i <= n; i++)
if (viz[i] == 0)
Dfs(i);
for (i = n; i >= 1; i--)
out << st[i] << " ";
return 0;
}