Pagini recente » Cod sursa (job #2265009) | Cod sursa (job #1259654) | Cod sursa (job #1048995) | Cod sursa (job #235359) | Cod sursa (job #1879653)
#include <iostream>
#include <fstream>
#include <vector>
using namespace std;
ifstream fin ("sortaret.in");
ofstream fout("sortaret.out");
int m,n, p, i, d[50005], f[50005], ok,a, k ,b, sol[50005],maxi,j;
vector <int> v[50005];
void dfs(int nod)
{
d[nod]=1;
int i, vecin;
for(i=0;i<v[nod].size();i++)
{
vecin=v[nod][i];
if(d[vecin]==0)
{
dfs(vecin);
}
}
sol[++k]=nod;
}
int main(){
fin>>n>>m;
for(i=1;i<=m;i++)
{
fin>>a>>b;
f[b]++;
v[a].push_back(b);
}
for(i=1;i<=n;i++)
if(f[i]==0)
{
dfs(i);
}
for(i=n;i>=1;i--)
fout<<sol[i]<<" ";
fin.close();
fout.close();
return 0;
}