Pagini recente » Istoria paginii runda/ah1 | Istoria paginii runda/simulare-cartita-18a | Autentificare | Monitorul de evaluare | Cod sursa (job #1108506)
#include<stdio.h>
#include<vector>
#include <queue>
using namespace std;
#define N 50000
int grd[N];
vector<int> graf[N];
queue<int> q;
int main()
{
freopen ("in.in","r",stdin);
freopen ("out.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();
cerr << nod << endl;
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;
}