欧拉回路
Posted transcendent-heming
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了欧拉回路相关的知识,希望对你有一定的参考价值。
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int edge[55][55],d[55];
void dfs(int mid) //寻找连通块
{
for(int k=1;k<=50;k++)
{
if(edge[mid][k])
{
edge[mid][k]--;
edge[k][mid]--;
dfs(k);
printf("%d %d
",k,mid); //一定要逆序输出,这样得到的才是答案
}
}
return;
}
int main(void)
{
int t,n,t0,i,j,x,y;
scanf("%d",&t);
for(t0=1;t0<=t;t0++)
{
memset(edge,0,sizeof(edge));
memset(d,0,sizeof(d));
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d%d",&x,&y);
edge[x][y]++;
edge[y][x]++;
d[x]++;
d[y]++;
}
printf("Case #%d
",t0);
for(i=1;i<=50;i++)
{
if(d[i]%2)
break;
}
if(i<=50)
printf("some beads may be lost
");
else
{
for(j=1;j<=50;j++)
dfs(j);
}
if(t0!=t)
printf("
");
}
}
以上是关于欧拉回路的主要内容,如果未能解决你的问题,请参考以下文章