Pagini recente » dot-com/2012/clasament/runda-1 | Cod sursa (job #3121861) | Cod sursa (job #3275307) | Cod sursa (job #3033116) | Cod sursa (job #3292210)
#include <bits/stdc++.h>
#define nmax 50002
using namespace std;
ifstream f("sortaret.in");
ofstream g("sortaret.out");
int n,m,dr,d[nmax],Q[nmax];
vector <int> L[nmax];
int main()
{ f>>n>>m;
for(int a,b; m; m--)
{f>>a>>b; L[a].push_back(b); d[b]++; }
for(int i=1; i<=n; i++)
if(d[i]==0) Q[++dr]=i;
int st=1;
while(st<=dr)
{ int x=Q[st];
vector <int> :: iterator it=L[x].begin(),sf=L[x].end();
for(; it!=sf; it++)
{ d[*it]--;
if(d[*it]==0) Q[++dr]=*it;
}
st++;
}
for(int i=1; i<=dr; i++) g<<Q[i]<<' ';
g.close();
f.close();
return 0;
}