离散数学(第13章)陈瑜.ppt
《离散数学(第13章)陈瑜.ppt》由会员分享,可在线阅读,更多相关《离散数学(第13章)陈瑜.ppt(93页珍藏版)》请在三一办公上搜索。
1、陈瑜,Email:yu2023/11/16,离散数学,计算机学院,2023/11/16,计算机科学与工程学院,2,第13章 欧拉图与哈密顿图,2023/11/16,计算机科学与工程学院,3,主要内容(1),Euler图及其应用 1)欧拉道路(回路)的定义 2)如何判别欧拉图 3)一个图含有欧拉道路的条件 4)连通有向图G中含有有向欧拉道路和回路的充要条件 5)Fleury算法 6)Euler图的应用(中国邮递员问题算法),2023/11/16,计算机科学与工程学院,4,主要内容(2),哈密顿图及其应用:哈密顿道路(圈)的定义连通图G是哈密顿图的必要条件连通图G是哈密顿图的充分条件连通图G是哈密
2、顿图的充要条件 哈密顿图的应用(推销商问题),2023/11/16,计算机科学与工程学院,5,哥尼斯堡七桥问题,哥尼斯堡城市有一条横贯全城的普雷格尔(Pregel)河,城的各部分用七座桥联接,每逢假日,城中居民进行环城逛游,这样就产生了一个问题:能不能设计一次“遍游”,使得从某地出发对每座跨河桥只走一次,而在遍历了七桥之后却又能回到原地?,2023/11/16,计算机科学与工程学院,6,Euler图,定义13-1.1设G是一个无孤立结点的图,包含G的每条边的简单道路(回路)称为该图的一条欧拉道路(回路)。具有欧拉回路的图称为欧拉图。规定平凡图为欧拉图。显然,每个欧拉图必然是连通图。,因此,一条
3、欧拉道路(回路)是经过图中每边一次且仅一次的道路(回路)。,为什么?,无重复边,2023/11/16,计算机科学与工程学院,7,Euler图,定义13-1.1设G是一个无孤立结点的图,包含G的每条边的简单道路(回路)称为该图的一条欧拉道路(回路)。具有欧拉回路的图称为欧拉图。规定平凡图为欧拉图。显然,每个欧拉图必然是连通图。,因此,一条欧拉道路(回路)是经过图中每边一次且仅一次的道路(回路)。,为什么?,2023/11/16,计算机科学与工程学院,8,Euler图,定义13-1.1设G是一个无孤立结点的图,包含G的每条边的简单道路(回路)称为该图的一条欧拉道路(回路)。具有欧拉回路的图称为欧拉
4、图。规定平凡图为欧拉图。显然,每个欧拉图必然是连通图。,因此,一条欧拉道路(回路)是经过图中每边一次且仅一次的道路(回路)。,为什么?,2023/11/16,计算机科学与工程学院,9,例13.1,图a是欧拉图;图b不是欧拉图,但存在欧拉道路;图c不存在欧拉道路。,2023/11/16,计算机科学与工程学院,10,定理13-1.1 无向连通图G是欧拉图当且仅当G的所有结点的度数都为偶数。,证明:“”设G是Euler图,则G必然存在一条包含所有边(也包含所有结点)的回路C,对uV,u必然在C中出现一次(可出现多次),每出现u一次,都关联着G中的两条边,而当u又重复出现时,它又关联着G中的另外的两条
5、边,(为什么?)因而u每出现一次,都将使得结点u的度数增加2度,若u在通路中重复出现j次,则deg(u)2j。即u的度数必为偶数。,2023/11/16,计算机科学与工程学院,11,定理13-1.1 无向连通图G是欧拉图当且仅当G的所有结点的度数都为偶数。,证明:“”设G是Euler图,则G必然存在一条包含所有边(也包含所有结点)的回路C,对uV,u必然在C中出现一次(可出现多次),每出现u一次,都关联着G中的两条边,而当u又重复出现时,它又关联着G中的另外的两条边,(为什么?)因而u每出现一次,都将使得结点u的度数增加2度,若u在通路中重复出现j次,则deg(u)2j。即u的度数必为偶数。,
6、2023/11/16,计算机科学与工程学院,12,定理13-1.1 无向连通图G是欧拉图当且仅当G的所有结点的度数都为偶数。,证明:“”设G是Euler图,则G必然存在一条包含所有边(也包含所有结点)的回路C,对uV,u必然在C中出现一次(可出现多次),每出现u一次,都关联着G中的两条边,而当u又重复出现时,它又关联着G中的另外的两条边,(为什么?)因而u每出现一次,都将使得结点u的度数增加2度,若u在通路中重复出现j次,则deg(u)2j。即u的度数必为偶数。,由于在回路C中边不可能重复出现,2023/11/16,计算机科学与工程学院,13,“”设连通图G的结点的度数都是偶数,则G必含有简单
7、回路(可用归纳法证明)。设C是一条包含G中边最多的简单回路:若C已经包含G中所有的边,则C就是Euler回路,结论成立。若C不能包含G中所有的边,则删边子图 G-E(C)仍然无奇数度结点。,由于G是连通的,C中应至少存在一点v,使G-E(C)中有一条包含v的回路C。(见示意图),2023/11/16,计算机科学与工程学院,14,“”设连通图G的结点的度数都是偶数,则G必含有简单回路(可用归纳法证明)。设C是一条包含G中边最多的简单回路:若C已经包含G中所有的边,则C就是Euler回路,结论成立。若C不能包含G中所有的边,则删边子图 G-E(C)仍然无奇数度结点。,由于G是连通的,C中应至少存在
8、一点v,使G-E(C)中有一条包含v的回路C。(见示意图),2023/11/16,计算机科学与工程学院,15,“”设连通图G的结点的度数都是偶数,则G必含有简单回路(可用归纳法证明)。设C是一条包含G中边最多的简单回路:若C已经包含G中所有的边,则C就是Euler回路,结论成立。若C不能包含G中所有的边,则删边子图 G-E(C)仍然无奇数度结点。,由于G是连通的,C中应至少存在一点v,使G-E(C)中有一条包含v的回路C。(见示意图),2023/11/16,计算机科学与工程学院,16,“”设连通图G的结点的度数都是偶数,则G必含有简单回路(可用归纳法证明)。设C是一条包含G中边最多的简单回路:
9、若C已经包含G中所有的边,则C就是Euler回路,结论成立。若C不能包含G中所有的边,则删边子图 G-E(C)仍然无奇数度结点。,由于G是连通的,C中应至少存在一点v,使G-E(C)中有一条包含v的回路C。(见示意图),2023/11/16,计算机科学与工程学院,17,这样,就可以构造出一条由C和C组成的G的回路,其包含的边数比C多,与假设矛盾。因此,C必是Euler回路,结论成立。,2023/11/16,计算机科学与工程学院,18,证明:“”设G具有一条Euler通路L,则在L中除起点和终点外,其余每个结点都与偶数条边相关联,所以,G中仅有零个(Euler回路)或者两个奇数度结点。“”:若
10、G没有奇度数结点,则结论显然成立;若G有两个奇度数结点u和v,则G+uv是Euler图,从而存在Euler回路C。从C中去掉边uv,则得到一条简单道路L(起点u和终点v),且包含了G的全部边,即L是一条Euler道路。注意:若有两个奇度数结点,则它们是G中每条欧拉通路的端点。,推论非平凡连通图G含有欧拉道路当且仅当G仅有零个或者两个奇数度结点。,2023/11/16,计算机科学与工程学院,19,证明:“”设G具有一条Euler通路L,则在L中除起点和终点外,其余每个结点都与偶数条边相关联,所以,G中仅有零个(Euler回路)或者两个奇数度结点。“”:若 G没有奇度数结点,则结论显然成立;若G有
11、两个奇度数结点u和v,则G+uv是Euler图,从而存在Euler回路C。从C中去掉边uv,则得到一条简单道路L(起点u和终点v),且包含了G的全部边,即L是一条Euler道路。注意:若有两个奇度数结点,则它们是G中每条欧拉通路的端点。,推论非平凡连通图G含有欧拉道路当且仅当G仅有零个或者两个奇数度结点。,2023/11/16,计算机科学与工程学院,20,证明:“”设G具有一条Euler通路L,则在L中除起点和终点外,其余每个结点都与偶数条边相关联,所以,G中仅有零个(Euler回路)或者两个奇数度结点。“”:若 G没有奇度数结点,则结论显然成立;若G有两个奇度数结点u和v,则G+uv是Eul
12、er图,从而存在Euler回路C。从C中去掉边uv,则得到一条简单道路L(起点u和终点v),且包含了G的全部边,即L是一条Euler道路。注意:若有两个奇度数结点,则它们是G中每条欧拉通路的端点。,推论非平凡连通图G含有欧拉道路当且仅当G仅有零个或者两个奇数度结点。,2023/11/16,计算机科学与工程学院,21,证明:“”设G具有一条Euler通路L,则在L中除起点和终点外,其余每个结点都与偶数条边相关联,所以,G中仅有零个(Euler回路)或者两个奇数度结点。“”:若 G没有奇度数结点,则结论显然成立;若G有两个奇度数结点u和v,则G+uv是Euler图,从而存在Euler回路C。从C中
13、去掉边uv,则得到一条简单道路L(起点u和终点v),且包含了G的全部边,即L是一条Euler道路。注意:若有两个奇度数结点,则它们是G中每条欧拉通路的端点。,推论非平凡连通图G含有欧拉道路当且仅当G仅有零个或者两个奇数度结点。,2023/11/16,计算机科学与工程学院,22,例13.2,由定理13-1.1及推论容易看出:,是欧拉图;不是欧拉图,但存在欧拉道路;既不是欧拉图,也不存在欧拉道路。,2023/11/16,计算机科学与工程学院,23,例13.2,由定理13-1.1及推论容易看出:,是欧拉图;不是欧拉图,但存在欧拉道路;既不是欧拉图,也不存在欧拉道路。,现在,我们是不是已经解决了哥尼斯
14、堡七桥问题?,2023/11/16,计算机科学与工程学院,24,有向图的欧拉道路、欧拉图,定理13-1.2(教材p253)有向连通图G含有有向欧拉道路,当且仅当除了两个结点以外,其余结点的入度等于出度,而这两个例外的结点中,一个结点的入度比出度大1,另一个结点的出度比入度大1。)有向连通图G含有有向欧拉回路,当且仅当G中的所有结点的入度等于出度。,类似于无向图的讨论,对有向图我们有以下结论:,同样,有向Euler图的结点度数都为偶数;含有有向Euler道路的图仅有零个或者两个奇度数结点。,2023/11/16,计算机科学与工程学院,25,有向图的欧拉道路、欧拉图,定理13-1.2(教材p253
15、)有向连通图G含有有向欧拉道路,当且仅当除了两个结点以外,其余结点的入度等于出度,而这两个例外的结点中,一个结点的入度比出度大1,另一个结点的出度比入度大1。)有向连通图G含有有向欧拉回路,当且仅当G中的所有结点的入度等于出度。,类似于无向图的讨论,对有向图我们有以下结论:,同样,有向Euler图的结点度数都为偶数;含有有向Euler道路的图仅有零个或者两个奇度数结点。,2023/11/16,计算机科学与工程学院,26,有向图的欧拉道路、欧拉图,定理13-1.2)有向连通图G含有有向欧拉道路,当且仅当除了两个结点以外,其余结点的入度等于出度,而这两个例外的结点中,一个结点的入度比出度大1,另一
16、个结点的出度比入度大1。)有向连通图G含有有向欧拉回路,当且仅当G中的所有结点的入度等于出度。,类似于无向图的讨论,对有向图我们有以下结论:,同样,有向Euler图的结点度数都为偶数;含有有向Euler道路的图仅有零个或者两个奇度数结点。,2023/11/16,计算机科学与工程学院,27,例13.3,V1,V2,V3,V4,V1,V2,V3,V4,V8,V2,V4,V6,V1,V3,V5,V7,图a)存在一条的欧拉道路:v3v1v2v3v4v1;,(a),(b),(c),图(b)中存在欧拉回路v1v2v3v4v1v3v1,因而(b)是欧拉图;,图(c)中有欧拉回路v1v2v3v4v5v6v7v
17、8v2v4v6v8v1因而(c)是欧拉图。,2023/11/16,计算机科学与工程学院,28,例13.4,解在图中,仅有两个度数为奇数的结点b,c,因而存在从b到c的欧拉通路,蚂蚁乙走到c只要走一条欧拉通路,边数为9条。而蚂蚁甲要想走完所有的边到达c,至少要先走一条边到达b,再走一条欧拉通路,因而它至少要走10条边才能到达c,所以乙必胜。,甲、乙两只蚂蚁分别位于右图,中的结点a,b处,并设图中的边长度是相等的。甲、乙进行比赛:从它们所在的结点出发,走过图中的所有边最后到达结点c处。如果它们的速度相同,问谁先到达目的地?,2023/11/16,计算机科学与工程学院,29,例13.4,解在图中,仅
18、有两个度数为奇数的结点b,c,因而存在从b到c的欧拉通路,蚂蚁乙走到c只要走一条欧拉通路,边数为9条。而蚂蚁甲要想走完所有的边到达c,至少要先走一条边到达b,再走一条欧拉通路,因而它至少要走10条边才能到达c,所以乙必胜。,甲、乙两只蚂蚁分别位于右图,中的结点a,b处,并设图中的边长度是相等的。甲、乙进行比赛:从它们所在的结点出发,走过图中的所有边最后到达结点c处。如果它们的速度相同,问谁先到达目的地?,2023/11/16,计算机科学与工程学院,30,Fleury算法(构造Euler回路),设G是一个欧拉图任取v0V,令P0v0;设P0v0e1v1e2eivi,按下面的方法从 GK=E-e1
19、,e2,ei中选取ei+1:ei+1与vi相关联;除非无别的边可选取,否则ei+1不应该为 GkG-e1,e2,ei中的桥;当Gk为零图时,算法结束;否则,返回2。,2023/11/16,计算机科学与工程学院,31,Fleury算法(构造Euler回路),设G是一个欧拉图任取v0V,令P0v0;设P0v0e1v1e2eivi,按下面的方法从 GK=E-e1,e2,ei中选取ei+1:ei+1与vi相关联;除非无别的边可选取,否则ei+1不应该为 GkG-e1,e2,ei中的桥;当Gk为零图时,算法结束;否则,返回2。,即如果ei+1是割边,同时还有其它边与vi相关联,则不能选ei+1,2023
20、/11/16,计算机科学与工程学院,32,Fleury算法(构造Euler回路),设G是一个欧拉图任取v0V,令P0v0;设P0v0e1v1e2eivi,按下面的方法从 GK=E-e1,e2,ei中选取ei+1:ei+1与vi相关联;除非无别的边可选取,否则ei+1不应该为 GkG-e1,e2,ei中的桥;当Gk为零图时,算法结束;否则,返回2。,即如果ei+1是割边,同时还有其它边与vi相关联,则不能选ei+1,能不走桥就不走桥!,2023/11/16,计算机科学与工程学院,33,Fleury算法(构造Euler回路),设G是一个欧拉图任取v0V,令P0v0;设P0v0e1v1e2eivi,
21、按下面的方法从 GK=E-e1,e2,ei中选取ei+1:ei+1与vi相关联;除非无别的边可选取,否则ei+1不应该为 GkG-e1,e2,ei中的桥;当Gk为零图时,算法结束;否则,返回2。,2023/11/16,计算机科学与工程学院,34,例13.5,v4,v5,v6,e4,e5,e6,e10,e9,e8,e3,在右图所示的欧拉图中,某人用算法求中的欧拉回路时,走了简单的回路:v2e2v3e3v4e14v9e10v2e1v1e8v8e9v2之后,无法行遍了,试分析在哪步他犯了错误?,v1,v3,v7,e1,e2,e7,v,e1,e1,e1,e1,v2,v4,v5,v6,e4,e5,e6,
22、e10,e9,e8,e3,v1,v3,v7,e1,e2,e7,v,e1,e1,e1,e1,v2,此人行遍v8时犯了能不走桥就不走桥的错误,因而未能行遍出欧拉回路。当他走到v8时,e2,e3,e14,e10,e1,e8,见右图,此时,e9为该图中的桥,而e7、e11均不是桥。因此,他不该走e9,而应该走e7或e11。但在行遍v3和v1时,也遇到桥,为什么没有问题呢?,v9,v9,2023/11/16,计算机科学与工程学院,35,中国邮递员问题,山东师范大学,管梅谷先生1962提出并解决。(参考文献:1962(数学通报)81.10,P32,81.5)一个邮递员从邮局出发,在其分管的投递区域内走遍所
23、有的街道把邮件送到每个收件人手中,最后又回到邮局,要走怎样的线路使全程最短。,这个问题用图来表示:街道为图的边,街道交叉口为图的结点,问题就是要从这样一个图中找出一条至少包含每条边一次的总长最短的回路。,2023/11/16,计算机科学与工程学院,36,对此,管梅谷曾证明,若图的边数为m,则所求回路的长度最小是m,最多不超过2m,并且每条边在其中最多出现两次。中国邮递员问题,一般为在带权连通图中找一条包括全部边的且权最小的回路。,这个问题有着有效的解决办法,其中最直观的方法之一是:把图中的某些边复制成两条边,然后在所求图中找一条欧拉回路。中国邮递员问题是运筹学中一个典型的优化问题。,显然,当这
24、个图是欧拉图时,任何一条欧拉回路都符合要求;当这个图不是欧拉图时,所求回路必然要重复通过某些边。,关键是:复制哪些边?,2023/11/16,计算机科学与工程学院,37,算法,(1)若G不含奇数度结点,则任一欧拉回路就是问题的解决。(2)若G含有2K(K0)个奇数度结点,则先求出其中任何两点间的最短路径,然后再在这些路径之中找出K条路径P1,P2,PK,使得满足以下条件:任何Pi和Pj(ij)没有相同的起点和终点。在所满足的K条最短路径的集合中,P1,P2,PK的长度总和最短。(3)根据(2)中求出的K条最短道路P1,P2,PK,在原图G中复制所有出现的在这条道路上的边,设所得之图为G。(4)
25、构造G的欧拉回路,即得中国邮递员问题的解。,找出需复制的边,连通图中,奇数度结点的个数必为偶数个。,2023/11/16,计算机科学与工程学院,38,例13.6,1因为G含有奇数度结点,所以2G中有2K=4(K=2)个奇结点:V1,V2,V3,V5。这4点间的距离:d(V1,V2)=3,d(V1,V3)=5,d(V1,V5)=4,d(V2,V3)=2,d(V2,V5)=3,d(V3,V5)=4各路径:V1V2(3),V3V5(4)7 V1V3(5),V2V5(3)8 V1V5(4),V2V3(2)6两条长度最短P1=V1V7V5,P2=V2V33构造G的任一E图就是中国邮递员问题的解。,G,G
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 离散数学 13 陈瑜

链接地址:https://www.31ppt.com/p-6595582.html