Mai intai trebuie sa te autentifici.
Cod sursa(job #2278412)
Utilizator | Data | 7 noiembrie 2018 23:43:23 | |
---|---|---|---|
Problema | Sortare topologica | Scor | 0 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.7 kb |
#include<fstream>
#include<vector>
using namespace std;
ifstream fin("sortaret.in");
ofstream fout("sortaret.out");
int ns,n,m,nr=0;
const int NMax=100005;
int v[NMax],k[NMax];
vector < int > a[NMax];
void dfs(int ns)
{
v[ns]=1;
for(int i=0;i<a[ns].size();i++)
{
int vecin=a[ns][i];
if(!v[vecin])
{
dfs(vecin);
}
}
k[nr++]=ns;
}
int main()
{
fin>>n>>m;
for(int i=1;i<=m;i++)
{
int x,y;
fin>>x>>y;
a[x].push_back(y);
}
for(int i=1;i<=n;i++)
{
if(v[i]==0)
dfs(i);
}
for(int i=n;i>0;i--)
{
fout<<k[i]<<" ";
}
}