Cod sursa(job #2802628)

Utilizator bogdan2405Strat Bogdan-Valentin bogdan2405 Data 18 noiembrie 2021 16:04:47
Problema Sortare topologica Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.76 kb
#include<bits/stdc++.h>

using namespace std;

ifstream f("sortaret.in");
ofstream g("sortaret.out");

vector<int> adjList[50001];
stack<int> q;
vector<int> visited;

void DFS(int x){
    int i;
    for(i=0;i<adjList[x].size();++i){
        if(visited[adjList[x][i]]==0){
            visited[adjList[x][i]]++;
            DFS(adjList[x][i]);
        }
    }

    q.push(x);
}

int main(){
    int n,m,i,a,b;
    f>>n>>m;

    for(i=0;i<n;++i){
        visited.push_back(0);
    }

    for(i=0;i<m;++i){
        f>>a>>b;
        adjList[a-1].push_back(b-1);
    }

    for(i=0;i<visited.size();++i){
        if(visited[i]==0){
            visited[i]++;
            DFS(i);
        }
    }

    while(!q.empty()){
        g<<q.top()+1<<' ';
        q.pop();
    }
    return 0;
}