Pagini recente » Cod sursa (job #2201298) | Cod sursa (job #1762339) | Cod sursa (job #3171726) | Cod sursa (job #2055529) | Cod sursa (job #1593064)
#include <cstdio>
#define NMAX 50005
using namespace std;
struct nod{
int info;
nod *next;
};
struct nod *v[NMAX],*h;
int t,n,m,viz[NMAX];
nod* push(nod* p,int x){
nod* elem=new nod;
elem->info=x;
elem->next=p;
return elem;
}
void DFS(int x){
if(viz[x]==0){
viz[x]=++t;
nod* parcurg=v[x];
while(parcurg){
DFS(parcurg->info);
parcurg=parcurg->next;
}
h=push(h,x);
}
}
void citire(){
scanf("%d%d",&n,&m);
int i,j,k;
for(k=m;k>=1;k--){
scanf("%d%d",&i,&j);
v[i]=push(v[i],j);
}
}
int main()
{
freopen("sortaret.in","r",stdin);
freopen("sortaret.out","w",stdout);
citire();
for(int i=1;i<=n;i++)
if(viz[i]==0)
DFS(i);
nod* parcurg=h;
while(parcurg){
printf("%d ",parcurg->info);
parcurg=parcurg->next;
}
return 0;
}