HDU 1878 欧拉回路(简单欧拉回路判定)
http://acm.hdu.edu.cn/showproblem.php?pid=1878
题意:给你N个点和M条无向边,问你这个图是否存在欧拉回路.
分析:无向图欧拉回路存在<==>图连通且所有点度为偶数
直接用并查集+degree处理即可.
AC代码:
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn=1000+10;
int n,m;
int degree[maxn];
int fa[maxn];
int findset(int i)
{
if(fa[i]==-1) return i;
return fa[i]=findset(fa[i]);
}
int main()
{
while(scanf("%d",&n)==1&&n)
{
scanf("%d",&m);
memset(degree,0,sizeof(degree));
memset(fa,-1,sizeof(degree));
for(int i=1;i<=m;i++)
{
int u,v;
scanf("%d%d",&u,&v);
degree[u]++;
degree[v]++;
u=findset(u), v=findset(v);
if(u!=v) fa[u]=v;
}
int cnt=0;//计数连通分量
for(int i=1;i<=n;i++)
if(findset(i)==i) cnt++;
if(cnt>1)
{
printf("0\n");
continue;
}
cnt=0;//计数奇数度的点
for(int i=1;i<=n;i++)
if(degree[i]%2==1) cnt++;
if(cnt!=0) printf("0\n");
else printf("1\n");
}
return 0;
}
分享到:
相关推荐
算法-欧拉回路(HDU-1878)(包含源程序).rar
hdu 1695 GCD(欧拉函数+容斥原理).docx
HDU的1250,主要是利用高精度加法,但是代码有点繁琐,效率不是很高
杭电ACMhdu1163
HDU1059的代码
hdu1001解题报告
hdu 1574 passed sorce
HDU的一题........HDU DP动态规
hdu 1005.比较简单的一道题,有兴趣的可以看看。
hdu2101AC代码
hdu ACM 各种排序
hdu acm 教案 搜索入门 hdu acm 教案 搜索入门
搜索 dfs 解题代码 hdu1241
hdu 5007 Post Robot 字符串枚举。 暴力一下就可以了。
hdu acm 教案 动态规划(1) hdu acm 教案 动态规划(1)
hdu 1166线段树代码
自己做的HDU ACM已经AC的题目
ACM HDU题目分类,我自己总结的大概只有十来个吧
HDU最全ac代码
hdu动态规划算法集锦