杭电 1878 欧拉回路

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 #include<cstdio>
 2 #include<string.h>
 3 int n,m,cnt,key,a,b,fa[1010],d[1010],i;
 4 int find(int a)
 5 {
 6     if(a == fa[a])
 7     {
 8         return a;
 9     }
10     else
11     {
12         return fa[a]=find(fa[a]);
13     }
14 }
15 void f1(int x,int y)
16 {
17     int nx,ny;
18     nx=find(x);
19     ny=find(y);
20     if(nx != ny)
21     {
22         fa[ny]=nx;
23     }
24 }
25 int main()
26 {
27     while(scanf("%d",&n) && n)
28     {
29         memset(d,0,sizeof(d));                //数组清零
30         for(i = 1 ; i <= n ; i++)
31         {
32             fa[i]=i;
33         }
34         scanf("%d",&m);
35         for(i = 0 ; i < m ; i++)
36         {
37             scanf("%d %d",&a,&b);
38             d[a]++;
39             d[b]++;                    //记录每个点的度数
40             f1(a,b);
41         }
42         cnt=0;key=0;
43         for(i = 1 ; i<= n ; i++)
44         {
45             if(d[i] % 2)        //判断每个点都是偶度
46             {
47                 key=1;
48             }
49             if(i == fa[i])        //判断没有独立的点
50             {
51                 cnt++;
52             }
53         }
54         if(cnt == 1)                //没有独立的点
55         {
56             if(key == 0)            //每个点的度数都是偶数
57             {
58                 printf("1\n");
59             }
60             else
61             {
62                 printf("0\n");
63             }
64         }
65         else
66         {
67             printf("0\n");
68         }
69     }
70  } 
时间: 2024-10-02 10:31:36

杭电 1878 欧拉回路的相关文章

杭电ACM1878——欧拉回路

简单的欧拉回路,如题. 欧拉回路的判断: 1.在有向图中:首先必要的条件是图连通,所以顶点的入度都等于出度. 2.在无向图中:首要条件还是图连通,其次就是所以顶点都是偶数度(该顶点的度为偶数) 这一题是无向图,所以根据判断方法来写,很简单,判定就不证明了. 我是用并查集来判断图是否连通的. 下面是AC的代码: #include <iostream> #include <cstring> using namespace std; int par[1005], degree[1005]

杭电 HDU 1164 Eddy&#39;s research I

Eddy's research I Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 7117    Accepted Submission(s): 4268 Problem Description Eddy's interest is very extensive, recently  he is interested in prime

hdu 1016 Prime Ring Problem DFS解法 纪念我在杭电的第一百题

Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 29577    Accepted Submission(s): 13188 Problem Description A ring is compose of n circles as shown in diagram. Put natural num

杭电ACM分类

杭电ACM分类: 1001 整数求和 水题1002 C语言实验题——两个数比较 水题1003 1.2.3.4.5... 简单题1004 渊子赛马 排序+贪心的方法归并1005 Hero In Maze 广度搜索1006 Redraiment猜想 数论:容斥定理1007 童年生活二三事 递推题1008 University 简单hash1009 目标柏林 简单模拟题1010 Rails 模拟题(堆栈)1011 Box of Bricks 简单题1012 IMMEDIATE DECODABILITY

一个人的旅行 HDU杭电2066【dijkstra算法】

http://acm.hdu.edu.cn/showproblem.php?pid=2066 Problem Description 虽然草儿是个路痴(就是在杭电待了一年多,居然还会在校园里迷路的人,汗~),但是草儿仍然很喜欢旅行,因为在旅途中 会遇见很多人(白马王子,^0^),很多事,还能丰富自己的阅历,还可以看美丽的风景--草儿想去很多地方,她想要去东京铁塔看夜景,去威尼斯看电影,去阳明山上看海芋,去纽约纯粹看雪景,去巴黎喝咖啡写信,去北京探望孟姜女--眼看寒假就快到了,这么一大段时间,可不

杭电1162--Eddy&#39;s picture(Prim()算法)

Eddy's picture Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 8070    Accepted Submission(s): 4084 Problem Description Eddy begins to like painting pictures recently ,he is sure of himself to b

杭电1276--士兵队列训练问题

士兵队列训练问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 4605    Accepted Submission(s): 2148 Problem Description 某部队进行新兵队列训练,将新兵从一开始按顺序依次编号,并排成一行横队,训练的规则如下:从头开始一至二报数,凡报到二的出列,剩下的向小序号方向靠拢,再从头开始进行

杭电1272 并查集找环+判断连通

杭电1272 并查集找环+判断连通 E - E Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status Practice HDU 1272 Description 上次Gardon的迷宫城堡小希玩了很久(见Problem B),现在她也想设计一个迷宫让Gardon来走.但是她设计迷宫的思路不一样,首先她认为所有的通道都应该是双向连通的,就是说如果有一个通道连通了房间A和B

杭电ACM Java实现样例

若使用Java求解杭电ACM,答案提交必须注意两点: 1.类名一定得是Main,否则服务器无法编译: 2.必须用while进行输入判断. 以1000题测试题为例,代码如下: import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scan=new Scanner(System.in); while(scan.hasNextInt()) { int a=scan.n