欧拉路知识点整理

题解报告:hdu 1878 欧拉回路

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

解题思路:

AC代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 typedef long long LL;
 4 const int maxn=1005;
 5 int T,n,m,deg[maxn],fa[maxn],a,b,f1,f2;
 6 void init(){
 7     for(int i=1;i<=n;++i)fa[i]=i;
 8 }
 9 int findt(int x){
10     int per=x,tmp;
11     while(fa[per]!=per)per=fa[per];
12     while(x!=per){tmp=fa[x];fa[x]=per;x=tmp;}
13     return x;
14 }
15 void unite(int x,int y){
16     x=findt(x),y=findt(y);
17     if(x!=y)fa[x]=y;
18 }
19 int main(){
20     while(cin>>n&&n){
21         cin>>m;
22         memset(deg,0,sizeof(deg));init();f1=f2=0;
23         while(m--){
24             cin>>a>>b;
25             deg[a]++,deg[b]++;
26             unite(a,b);
27         }
28         for(int i=1;i<=n;++i)
29             f1+=(i==fa[i]?1:0),f2+=(deg[i]&1?0:1);
30         if(f1==1&&f2==n)puts("1");///欧拉回路
31         else puts("0");
32
33     }
34     return 0;
35 }

题解报告:NYOJ 42 一笔画问题

Problem Description

zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下来。规定,所有的边都只能画一次,不能重复画。

Input

第一行只有一个正整数N(N<=10)表示测试数据的组数。
每组测试数据的第一行有两个正整数P,Q(P<=1000,Q<=2000),分别表示这个画中有多少个顶点和多少条连线。(点的编号从1到P)
随后的Q行,每行有两个正整数A,B(0<A,B<P),表示编号为A和B的两点之间有连线。

Output

如果存在符合条件的连线,则输出"Yes",如果不存在符合条件的连线,输出"No"。

Sample Input

2
4 3
1 2
1 3
1 4
4 5
1 2
2 3
1 3
1 4
3 4

Sample Output

No
Yes

解题思路:

AC代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 typedef long long LL;
 4 const int maxn=1005;
 5 int T,n,m,deg[maxn],fa[maxn],a,b,f1,f2;
 6 void init(){
 7     for(int i=1;i<=n;++i)fa[i]=i;
 8 }
 9 int findt(int x){
10     int per=x,tmp;
11     while(fa[per]!=per)per=fa[per];
12     while(x!=per){tmp=fa[x];fa[x]=per;x=tmp;}
13     return x;
14 }
15 void unite(int x,int y){
16     x=findt(x),y=findt(y);
17     if(x!=y)fa[x]=y;
18 }
19 int main(){
20     while(cin>>n>>m){
21         memset(deg,0,sizeof(deg));init();f1=f2=0;///f1判断是否是连通图,f2统计每个节点的度
22         while(m--){
23             cin>>a>>b;
24             deg[a]++,deg[b]++;
25             unite(a,b);
26         }
27         for(int i=1;i<=n;++i)
28             f1+=(i==fa[i]?1:0),f2+=(deg[i]&1?0:1);
29         if(f1==1&&(f2==n||n-f2==2))puts("Yes");///如果每个节点的度都是偶数,或者有两个奇数度的节点,就能一笔画出
30         else puts("No");
31
32     }
33     return 0;
34 }

原文地址:https://www.cnblogs.com/acgoto/p/10046938.html

时间: 2024-10-18 02:07:06

欧拉路知识点整理的相关文章

HDU5883 The Best Path(并查集+欧拉路)

题意: n个点m条边,问m条边构成的是否为欧拉路. 是的话输出路径上所有点的异或和,每个点经过几次异或几次. 思路: 先用并查集判断是否连通,然后如果是欧拉路的话有两种情况 如果奇数度节点有2个,就枚举这两个点做起点,选大的 如果都为偶数度节点,就枚举n个起点,选大的 /* *********************************************** Author :devil ************************************************ *

CCF 201512-4 送货 (并查集+DFS,欧拉路)

问题描述 为了增加公司收入,F公司新开设了物流业务.由于F公司在业界的良好口碑,物流业务一开通即受到了消费者的欢迎,物流业务马上遍及了城市的每条街道.然而,F公司现在只安排了小明一个人负责所有街道的服务. 任务虽然繁重,但是小明有足够的信心,他拿到了城市的地图,准备研究最好的方案.城市中有n个交叉路口,m条街道连接在这些交叉路口之间,每条街道的 首尾都正好连接着一个交叉路口.除开街道的首尾端点,街道不会在其他位置与其他街道相交.每个交叉路口都至少连接着一条街道,有的交叉路口可能只连接着一 条或两

欧拉路

欧拉路径和欧拉回路欧拉路径:从某结点出发一笔画成所经过的路线叫做欧拉路径.欧拉回路:在欧拉路径的基础上又回到起点.a.凡是由偶点组成的连通图,一定可以一笔画成.画时可以把任一偶点为起点,最后一定能以这个点为 终点画完此图. b.凡是只有两个奇点的连通图(其余都为偶点),一定可以一笔画成.画时必须把一个奇点为起点,另 一个奇点终点. c.其他情况的图都不能一笔画出.(有偶数个奇点除以2便可算出此图需几笔画成.) 欧拉回路和欧拉路径的判断欧拉回路:无向图:每个顶点的度数都是偶数,则存在欧拉回路.有向

图的路径:欧拉路(欧拉回路)

欧拉路的相关概念: 1.能从无向图中的一个顶点出发,并走出一条道路,每条边恰好经过一次,这样的路线就叫做欧拉路: 2.找欧拉路首先要判断是否存在欧拉路: 一个无向图存在欧拉路当且仅当该图是连通的,且有且只有0或2个点的度数是奇数,为2时这两个点只能作为欧拉路径的起点和终点(0个时称为欧拉回路). 3.确定存在欧拉路之后,开始构造欧拉路: 欧拉路参考:http://blog.csdn.net/shahdza/article/details/6630108 等做完题,再来补充.

POJ 2513--Colored Sticks【字典树编号 &amp;&amp; 并查集判连通 &amp;&amp; 欧拉路】

Colored Sticks Time Limit: 5000MS   Memory Limit: 128000K Total Submissions: 32351   Accepted: 8536 Description You are given a bunch of wooden sticks. Each endpoint of each stick is colored with some color. Is it possible to align the sticks in a st

poj 1386 Play on Words(有向图欧拉路+并查集)

题目链接:http://poj.org/problem?id=1386 思路分析:该问题要求判断单词是否能连接成一条直线,转换为图论问题:将单词的首字母和尾字母看做一个点,每个单词描述了一条从首字母指向尾字母的有向边, 则则所有的单词构成了一个有向图,问题变为判断该有向图中是否存在一条欧拉路:有向图中存在欧拉路的两个充分必要条件为:该图是联通的并且所有的点的入度等于出度或者只存在两个点的入度与出度不等,一个点的入度=出度+1,另一个点的入度=出度-1: 代码如下: #include <cstdi

hihoCoder #1176 : 欧拉路&#183;一 (简单)

题意:给出n个岛,每个岛都有桥到达其他岛,且桥数可多可少(即使两岛有多桥),判断是否是欧拉路(即每条桥只能走一次,所有桥都能遍历1遍). 思路: 满足如下条件之一者即为欧拉路: 1.连通图,每个岛的度数为偶数. 2.连通图,其中两个岛的度比为奇数. 1 #include <bits/stdc++.h> 2 using namespace std; 3 const int N=10005; 4 vector< vector<int> > vect; 5 bool vis[

hihoCoder #1181: 欧拉路&#183;二 (麻烦)

题意:提供一个图,要求找出欧拉路的路径(任意合法的路径均可,保证图肯定有欧拉路). 思路:深搜的过程中删除遍历过的边,并在回溯时打印出来.在深搜时会形成多个环路,每个环都有一个或多个结点与其他环相扣,这样就可以产生欧拉路. 1 #include <bits/stdc++.h> 2 using namespace std; 3 const int N=1005; 4 int n, m, a, b; 5 vector< vector<int> > vect;//邻接表 6

Codeforces 789D Weird journey - 欧拉路 - 图论

Little boy Igor wants to become a traveller. At first, he decided to visit all the cities of his motherland — Uzhlyandia. It is widely known that Uzhlyandia has n cities connected with m bidirectional roads. Also, there are no two roads in the countr