欧拉回路

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(" ");
}
}

以上是关于欧拉回路的主要内容,如果未能解决你的问题,请参考以下文章

欧拉回路混合图的欧拉回路

欧拉除了函数,还有个回路----图论之路之欧拉路径欧拉回路

欧拉回路——欧拉路与欧拉回路

欧拉道路与欧拉回路

欧拉回路

欧拉回路与欧拉路径