Pagini recente » Cod sursa (job #433643) | Cod sursa (job #76832) | Cod sursa (job #812491) | Cod sursa (job #3156428) | Cod sursa (job #1437638)
#include <fstream>
#define dim 50001
#include <vector>
using namespace std;
ifstream fin("sortaret.in");
ofstream fout("sortaret.out");
vector <int> G[dim];
int Q[dim],deg[dim],a,b,i,n,m,x;
int main()
{
fin>>n>>m;
for(i=1;i<=m;i++)
{
fin>>a>>b;
G[a].push_back(b);
deg[b]++;
}
for(i=1;i<=n;i++)
if(deg[i]==0)
Q[++Q[0]]=i;
vector<int>::iterator it;
for(i=1;i<=n;i++)
{
x=Q[i];
for(it=G[x].begin();it!=G[x].end();it++)
{
deg[*it]--;
if(deg[*it]==0)
Q[++Q[0]]=*it;
}
}
for(i=1;i<=n;i++)
fout<<Q[i]<<" ";
return 0;
}