Pagini recente » Cod sursa (job #1725686) | Cod sursa (job #736920) | Cod sursa (job #1612263) | Cod sursa (job #3150685) | Cod sursa (job #2120695)
#include <fstream>
#include <unordered_map>
#include <vector>
using namespace std;
ifstream f ("sortaret.in");
ofstream g ("sortaret.out");
const int nmax=5e4+3;
unordered_map <int,int> viz[nmax];
int n,m,a,b,grad[nmax],sol[nmax],k,nod;
vector <int> v[nmax];
int main()
{
f>>n>>m;
while(m--)
{
f>>a>>b;
++viz[a][b];
if(viz[a][b]==1)
{
v[a].push_back(b);
++grad[b];
}
}
for(int i=1;i<=n;++i) if(!grad[i]) sol[++k]=i;
for(int i=1;i<=k;++i)
{
nod=sol[i];
for(int j=0;j<v[nod].size();++j)
{
--grad[v[nod][j]];
if(!grad[v[nod][j]]) sol[++k]=v[nod][j];
}
}
for(int i=1;i<=n;++i) g<<sol[i]<<' ';
return 0;
}