欧拉回路

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 9797    Accepted Submission(s): 3554

Problem Description
欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路。现给定一个图,问是否存在欧拉回路?
 
Input
测试输入包含若干测试用例。每个测试用例的第1行给出两个正整数,分别是节点数N ( 1 < N < 1000 )和边数M;随后的M行对应M条边,每行给出一对正整数,分别是该条边直接连通的两个节点的编号(节点从1到N编号)。当N为0时输入结
束。
 
Output
每个测试用例的输出占一行,若欧拉回路存在则输出1,否则输出0。
 
Sample Input
3 3
1 2
1 3
2 3
 
3 2
1 2
2 3
0
 
Sample Output
1
0
   算法分析:此题考察欧拉回路是否存在。要知道欧拉回路和欧拉道路是不一样的。欧拉回路存在则一定存在欧拉道路,但是欧拉道路存在则不一定存在欧拉回路!
   因为欧拉道路不一定是一个回路,也就是说,只要能把所有的节点连接起来就是一条欧拉道路了,但不一定能顺利回到起点。
  
   关于欧拉路径问题的理论总结:
   1)能否从一个无向图的一个节点出发走出一条道路,每条边恰好经过一次,这样的路线成为欧拉回路。“就是一个一笔画”
   2)欧拉道路存在定理:如果一个无向图是连通的,且最多只有2个奇点,则一定存在。  (奇点:节点度数为奇数的点)
       如果有2个奇点,则必须从其中一个出发,另一个奇点终止。
       如果奇点不存在,则可以从任意节点出发,最终定会回到该点。
   3)有向图下的理论:
     大前提:  在忽略边的方向后,图必须是连通的,否则不可能存在欧拉道路。
     有向图最多只能有两个节点的入度不等于出度,而且必须是出度比入度大1的节点做起点,入度比出度大1的节点做终点。
  
    此题的代码:

#include <stdio.h>
#include <string.h>
#include <iostream>
#include <string>
#include <algorithm>
#define N 1000+2 using namespace std;
bool map[N][N];
int odd[N];
bool vis[N];
int n; void dfs(int dd) //测试图的连通性
{
for(int i=1; i<=n; i++)
{
if(!vis[i] && map[dd][i]==true )
{
vis[i]=true;
dfs(i);
}
}
} int main()
{
int m;
int i, j;
int dd; //计数奇点的数目
int u,v; while(scanf("%d", &n)!=EOF)
{
if(n==0)
break;
scanf("%d", &m);
for(i=0; i<=n; i++)
{
for(j=0; j<=n; j++)
{
map[i][j]=false;
}
}
memset(odd, 0, sizeof(odd)); for(i=0; i<m; i++)
{
scanf("%d %d", &u, &v);
map[u][v]=true;
map[v][u]=true;
odd[u]++;
odd[v]++;
}
for(i=1; i<=n; i++)
vis[i]=false; int ans=0; //计算连通分量的个数
for(i=1; i<=n; i++)
{
if(!vis[i])
{
ans++;
vis[i]=true;
dfs(i);
}
}
if(ans==1) //连通分量的个数为1,说明图是连通的
{
dd=0;
for(i=1; i<=n; i++ )
{
if(odd[i]%2==1) //统计奇点的个数
dd++;
}
if( dd==0 ) //如果奇点的个数为0,则说明存在欧拉回路
printf("1\n");
else
printf("0\n");
}
else
printf("0\n");
}
return 0;
}
   

HDU 1878(1Y) (判断欧拉回路是否存在 奇点个数为0 + 一个联通分量 *【模板】)的更多相关文章

  1. hdu 1878 无向图的欧拉回路

    原题链接 hdu1878 大致题意: 欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路.现给定一个无向图,问是否存在欧拉回路? 思路: 无向图存在欧拉回路的条件:1.图是连 ...

  2. hdu 3352 求边双联通分量模板题(容器)

    /*这道题是没有重边的,求加几条边构成双联通,求边联通分量,先求出桥然后缩点,成一个棵树 找叶子节点的个数*/ #include<stdio.h> #include<string.h ...

  3. Sightseeing tour HDU - 1956(混合欧拉回路)

    题意: 有n个点,m条边,其中有单向边和双向边,求是否存在欧拉回路 解析: 刚开始想...判断一下每个点的度数不就好了...emm..还是年轻啊.. 判断是解决不了问题的,因为可能会有某两个点冲突,比 ...

  4. lua判断表中数据是否连续,0可以代表任何数

    最近看到有lua面试题,挺有意思的,一张表中有若干个数,0可以代表任何数 比如有张表{9, 2, 4, 1, 3, 0, 0, 0, 0},按照规则这张表中的四个0可以用来代表5,6,7,8,那么这张 ...

  5. HDU 1269 迷宫城堡 【强联通分量(模版题)】

    知识讲解: 在代码里我们是围绕 low 和 dfn 来进行DFS,所以我们务必明白 low 和 dfn 是干什么的? 有什么用,这样才能掌握他.   1.  dfn[]  遍历到这个点的时间 2.   ...

  6. hdu 5919 主席树(区间不同数的个数 + 区间第k大)

    Sequence II Time Limit: 9000/4500 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Tot ...

  7. 【强联通图 | 强联通分量】HDU 1269 迷宫城堡 【Kosaraju或Tarjan算法】

      为了训练小希的方向感,Gardon建立了一座大城堡,里面有N个房间(N<=10000)和M条通道(M<=100000),每个通道都是单向的,就是说若称某通道连通了A房间和B房间,只说明 ...

  8. HDU 1878 欧拉回路(判断欧拉回路)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1878 题目大意:欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路.现给定一 ...

  9. HDU - 1878 欧拉回路 (连通图+度的判断)

    欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路.现给定一个图,问是否存在欧拉回路? Input 测试输入包含若干测试用例.每个测试用例的第1行给出两个正整数,分别是节点数 ...

随机推荐

  1. 洛谷——P1588 丢失的牛

    P1588 丢失的牛 题目描述 FJ丢失了他的一头牛,他决定追回他的牛.已知FJ和牛在一条直线上,初始位置分别为x和y,假定牛在原地不动.FJ的行走方式很特别:他每一次可以前进一步.后退一步或者直接走 ...

  2. Maven 项目打包发布

    在Eclipse左侧右击项目,Debug As -> Debug Configurations -> 双击Maven Build 然后看弹出框的右侧右侧的Name随便填写一个名字,Base ...

  3. 【spring cloud】spring cloud服务发现注解之@EnableDiscoveryClient与@EnableEurekaClient

    spring cloud服务发现注解之@EnableDiscoveryClient与@EnableEurekaClient的区别

  4. GO -- socket读取内容

    func handleRead(conn net.Conn, done chan string) { for { buf := make([]) reqLen, err := conn.Read(bu ...

  5. Linux中的热键[Tab] [Ctrl]-c [Ctrl]-d

    Tab键:命令或者文件补全.可以避免很多的输入错误 1. 按一次,文件或命令补全 2. 按两次,会列举出以按键前的字母为首的所有命令或者文件 Ctrl+C:中断目前程序 Ctrl+D:键盘输入结束.可 ...

  6. cug oj 1479 Treasure Chest Lock (区间dp 思维)

    1479: Treasure Chest Lock Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 7  Solved: 5 [id=1479" ...

  7. vs2012编译ffmpeg

    从官方网站down下来的ffmpeg没有pdb文件不方便调试,为此使用VS2012编译ffmpeg. 编译步骤: 一.安装MinGW,具体的安装方法上一篇文章已经有介绍这里不在赘述. 二.下载文件并放 ...

  8. C# 利用ICSharpCode.SharpZipLib实现在线加密压缩和解密解压缩 C# 文件压缩加解密

    C# 利用ICSharpCode.SharpZipLib实现在线加密压缩和解密解压缩   这里我们选用ICSharpCode.SharpZipLib这个类库来实现我们的需求. 下载地址:http:// ...

  9. MOS管驱动详解

    1.常用的几种电平转换方案 2.三极管的电平转换及驱动电路分析 3.三级管老怀 4.关于MOSFET管驱动电路总结 5.一个IIC的5V和3.3V电平转换的经典电路分享 6.mos 7.mos应用 8 ...

  10. 关于提高沟通能力的书单 | 章鱼书单zz

    上周推荐了一份关于提高写作能力的书单,这周,我们来聊聊沟通能力. 在现代社会,沟通能力变得越来越重要.人与人之间的社交渠道越来越丰富,工作中的协同合作也越来越普遍.我们要沟通的人越来越多,节奏越来越快 ...