Pagini recente » Cod sursa (job #67216) | Cod sursa (job #2695155) | Cod sursa (job #374072) | Cod sursa (job #1171195) | Cod sursa (job #1333215)
#include<fstream>
#include<algorithm>
#include<vector>
#include<queue>
using namespace std;
ifstream f("sortaret.in");
ofstream g("sortaret.out");
vector<int> v[50010];
int x,q[50010],pr,ul,n,m,i,j,a,b,gr[50010];
int main()
{
f>>n>>m;
for(i=1;i<=m;i++)
{
f>>a>>b;
gr[b]++;
v[a].push_back(b);
}
pr=1;
ul=0;
for(i=1;i<=n;i++)
{
if(!gr[i])
q[++ul]=i;
}
while(ul<n)
{
x=q[pr++];
for(vector<int>::iterator it=v[x].begin();it!=v[x].end();it++)
{
a=*it;
gr[a]--;
if(!gr[a])
q[++ul]=a;
}
}
for(i=1;i<=n;i++)
g<<q[i]<<" ";
g<<'\n';
return 0;
}