Pagini recente » Cod sursa (job #509813) | Cod sursa (job #2734485) | Cod sursa (job #928145) | Cod sursa (job #1301093) | Cod sursa (job #355439)
Cod sursa(job #355439)
#include<stdio.h>
#define nmax 50001
#define mmax 2000
int n,m,i,x,y,nr;
int ad[nmax][mmax], viz[nmax], post[nmax];
void read()
{
freopen("sortaret.in", "r", stdin);
freopen("sortaret.out", "w", stdout);
scanf("%d %d", &n, &m);
for(i=1;i<=m;i++)
{
scanf("%d %d", &x, &y);
ad[x][++ad[x][0]]=y;
}
}
void dfs(int x)
{
int j;
viz[x]=0;
for(j=1;j<=ad[x][0];j++)
if(!viz[ad[x][j]])
dfs(ad[x][j]);
post[++nr]=x;
}
int main()
{
read();
for(i=1;i<=n;i++)
if(!viz[i])
dfs(i);
for(i=n;i>=1;i--)
printf("%d ", post[i]);
printf("\n");
return 0;
}