Pagini recente » Cod sursa (job #499813) | Cod sursa (job #1125438) | Cod sursa (job #2227379) | Cod sursa (job #62863) | Cod sursa (job #1108769)
#include<stdio.h>
#include<vector>
#include <queue>
using namespace std;
#define N 100000
int grd[N];
vector<int> graf[N];
queue<int> q;
int main()
{
freopen ("sortaret.in","r",stdin);
freopen ("sortaret.out","w",stdout);
int n,m;
scanf ("%d %d",&n,&m);
for (int i=0, a, b;i<m;i++)
{
scanf ("%d %d", &a, &b);
graf[a].push_back(b);
grd[b]++;
}
for (int i = 1; i <= n; i++)
if (grd[i] == 0) q.push(i);
while (!q.empty())
{
int nod = q.front();
q.pop();
for(int j = 0; j < graf[nod].size(); j++)
if (--grd[graf[nod][j]] == 0)
q.push(graf[nod][j]);
printf("%d ",nod);
}
return 0;
}