Cod sursa(job #261089)

Utilizator RobybrasovRobert Hangu Robybrasov Data 17 februarie 2009 21:05:53
Problema Sortare topologica Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.69 kb
#include <cstdio>
#include <vector>
#include <queue>
#define N 50001

using namespace std;

int V[N],n,m,i,x,y;
vector<int> L[N];
vector<int>::iterator it;
queue<int> C;

int main()
{
	freopen("sortaret.in","r",stdin);
	freopen("sortaret.out","w",stdout);
	scanf("%d%d\n",&n,&m);
	for (i=1; i<=m; i++)
	{
	    scanf("%d%d\n",&x,&y);
	    L[x].push_back(y);
	    V[y]++;
	}
    for (i=1; i<=n; i++)
        if (!V[i]) C.push(i);
    for (; !C.empty(); C.pop())
    {
        printf("%d ",C.front());
        for (it=L[C.front()].begin(); it!=L[C.front()].end(); it++)
        {
            V[*it]--;
            if (!V[*it]) C.push(*it);
        }
    }

    return 0;
}