Cod sursa(job #3030270)

Utilizator Glue02Tudorescu Ioan Daniel Glue02 Data 17 martie 2023 16:24:51
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.72 kb
#include <fstream>
#include <vector>
#include <stack>
#include <set>
using namespace std;

ifstream cin("sortaret.in");
ofstream cout("sortaret.out");
vector <set<int> > G;
int n,m,ctc;
vector <int> viz,s;
void DFS(int start)
{
    viz[start]=1;
    for(auto it:G[start])
        if(!viz[it])
        {
            DFS(it);
        }
    s.push_back(start);
}

int main()
{
    cin>>n>>m;
    G.resize(n+1);
    viz.resize(n+1);
    while(m--)
    {
        int x,y;
        cin>>x>>y;
        if(G[x].find(y) == G[x].end()) G[x].insert(y);
    }
    for(int i=1;i<=n;++i)
        if(!viz[i])
            DFS(i);
    for(auto it=s.rbegin(); it!=s.rend(); it++)
        cout<<*it<<' ';
    return 0;
}