Cod sursa(job #1390196)

Utilizator zpaePopescu Andreea zpae Data 16 martie 2015 21:45:43
Problema Sortare topologica Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.72 kb
#include <fstream>
#include <vector>
using namespace std;
#define N 5005
int n,m,u[N],q[N];
int a[N][N];
vector <int> v;
ifstream in ("sortaret.in");
ofstream out ("sortaret.out");


int df(int k)
{
    u[k]=1;
    for(int i=1;i<=n;i++)
        if(a[k][i]==1&&u[i]==0)
            df(i);
    if(!q[k])
    {
        v.push_back(k);
        q[k]=1;
    }
    u[k]=0;
}

int main()
{
    int x,y;
    in>>n>>m;
    while(m--)
    {
        in>>x>>y;
        a[x][y]=1;
        a[y][x]=1;
        //v[y].push_back(x);
    }
    df(1);
    for(int i=0;i<v.size();i++)
        out<<v[i]<<' ';
    for(int i=1;i<=n;i++)
        if(q[i]==0)
            out<<i<<' ';
    out<<"\n";
    return 0;
}