Pagini recente » Cod sursa (job #916961) | Cod sursa (job #927290) | Cod sursa (job #1705256) | Cod sursa (job #2917186) | Cod sursa (job #2139304)
#include<bits/stdc++.h>
using namespace std;
ifstream fin("sortaret.in");
ofstream fout("sortaret.out");
int sol[50005], n,m, p=0, viz[50005];
vector<int> L[50005];
void DFS_TF(int k)
{ viz[k]=1;
for(auto i : L[k])
if(viz[i]==0) DFS_TF(i);
sol[++p] = k;
}
void SortareTopologica()
{
int i;
for (i = 1; i <= n; i++)
if (viz[i] == 0)
DFS_TF(i);
for (i = n; i >= 1; i--)
fout << sol[i] << " ";
}
int main()
{
int i,x,y;
fin>>n>>m;
for(i=1;i<=m;i++)
{
fin>>x>>y;
L[x].push_back(y);
}
SortareTopologica();
return 0;
}