Pagini recente » Cod sursa (job #1833078) | Cod sursa (job #1367668) | Cod sursa (job #16428) | Cod sursa (job #2111013) | Cod sursa (job #1375663)
using namespace std;
#include <fstream>
#include <vector>
ifstream f("sortaret.in");
ofstream g("sortaret.out");
vector <int> G[50001];
int gr[50001], n, m;
int coada[50001], k=0;
void parcurgere(int p)
{
vector <int> :: iterator it;
for(it=G[p].begin(); it!=G[p].end(); it++)
if(gr[*it]>0)
{
gr[*it]--;
if(gr[*it]==0)
{
k++;
coada[k]=*it;
}
}
}
int main()
{
int i, j, p, a, b;
f>>n>>m;
for(i=1; i<=m; i++)
{
f>>a>>b;
G[a].push_back(b);
gr[b]++;
}
for(i=1;i<=n;i++)
{
if(gr[i]==0)
{
k++;
coada[k]=i;
}
}
j=1;
while(j<=k)
{
p=coada[j];
g<<p<<' ';
parcurgere(p);
j++;
}
return 0;
}