【USACO3-3-1】骑马修栏杆 欧拉回路

原题

一笔画问题模版!

#include
#include
#include
#include

using namespace std;

#define M 1005

stack s;
int r[M][M];
int du[M];
int n=0,m;

void dfs(int x)
{
    for (int i=1;i<=n;i++)
    {
        if (r[x][i])
        {
            r[x][i]--;r[i][x]--;
            dfs(i);
        }
    }
    s.push(x);
}

int main()
{
    scanf("%d",&m);
    for (int i=1;i<=m;i++)
    {
        int x,y;
        scanf("%d%d",&x,&y);
        n=max(y,max(n,x));
        du[x]++;du[y]++;
        r[x][y]++;r[y][x]++;
    }
    int sta=1;
    for (int i=1;i<=n;i++)
        if (du[i]%2==1){sta=i;break;}
    dfs(sta);
    while(!s.empty()) printf("%d\n",s.top()),s.pop();
    return 0;
}

你可能感兴趣的:(USACO,图论-杂题)