Cod sursa(job #1829815)

Utilizator GeanaVladGeana Vlad GeanaVlad Data 15 decembrie 2016 17:49:51
Problema Ciclu Eulerian Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 0.72 kb
#include <iostream>
#include<fstream>
#include<vector>
using namespace std;
ifstream f("ciclueuler.in");
ofstream g("ciclueuler.out");
vector<int>v[100001];
int n,m,i,x,y;
void sterge(int x,int y)
{
    bool ok=1;
    for(int k=0;k<v[x].size()&&ok;k++)
        if(v[x][k]==y)
    {
        ok=0;
        swap(v[x][k],v[x][v[x].size()-1]);
        v[x].pop_back();
    }
}
void euler(int nod)
{
    while(v[nod].size())
    {
        int vec=v[nod][0];
        sterge(nod,vec);
        sterge(vec,nod);
        euler(vec);
    }
    g<<nod<<' ';
}
int main()
{
    f>>n>>m;
    for(i=1;i<=m;i++)
    {
        f>>x>>y;
        v[x].push_back(y);
        v[y].push_back(x);
    }
    euler(1);
}