(lecture092)二分图及其应用_第1页
(lecture092)二分图及其应用_第2页
(lecture092)二分图及其应用_第3页
(lecture092)二分图及其应用_第4页
(lecture092)二分图及其应用_第5页
已阅读5页,还剩33页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、11.09.20221ACM 程序设计信息学院计算机应用系 余腊生.11.09.20222今天,请个假,下周调课(西安).11.09.20223每周一星(8):05072120.11.09.20224第九讲二分图及其应用(Bipartite Graph & Applications).11.09.20225主要内容什么是二分图二分图的最大匹配匈牙利算法二分图的最小顶点覆盖DAG图的最小路径覆盖二分图的最大独立集处理技巧.11.09.20226什么是二分图?如果一个图的顶点可以分为两个集合X和Y,图的所有边一定是有一个顶点属于集合X,另一个顶点属于集合Y,则称该图为“二分图”( Bipartit

2、e Graph ).11.09.20227例:婚配问题男女.11.09.20228二分图的最大匹配 在二分图的应用中,最常见的就是最大匹配问题,很多其他的问题都可以通过转化为匹配问题来解决。.11.09.20229如何求二分图的最大匹配呢?.11.09.202210经典算法:匈牙利算法.11.09.202211/*hdoj_1150匈牙利算法 月下版 */#include#include#includeusing namespace std;bool mark1100,mark2100;int list100;int n,m,edge,num;vectorvector v;bool dfs(i

3、nt to)register int i,point,s = listto;for(i=0;ivs.size();i+)point = vsi;if(!mark2point)continue;mark2point = false;if(listpoint=-1 | dfs(point)listpoint = s;return true;return false; void Solve()int i,j,point;bool flog = false;memset(mark1,true,sizeof(mark1);memset(list,-1,sizeof(list);num=0;for(i=0

4、;in;i+)for(j=0;jvi.size();j+)if(listvij = -1)mark1i = false;listvij = i;num+;if(i=0) flog = true;break; for(i=0;in;i+)if(mark1i)if(!vi.empty()memset(mark2,true,sizeof(mark2);for(j=0;jvi.size();j+)point = vij;if(!mark2point) continue;mark2point = false;if(listpoint = -1 | dfs(point)listpoint = i;num+

5、;break; mark1i = false; if(flog | list0 != -1)cout num-1 endl;else cout num n)if(n = 0)break;v.clear();v.resize(n);cin m edge;for(i=0;i j s d;vs.push_back(d); Solve(); return 0; .11.09.202212匈牙利算法(求二分图最大匹配)谈匈牙利算法自然避不开Hall定理Hall定理:对于二分图G,存在一个匹配M,使得X的所有顶点关于M饱和的充要条件是:对于X的任意一个子集A,和A邻接的点集为T(A),恒有: |T(A)|

6、 = |A| .11.09.202213图示(1):男1男2女1女2女3返回.11.09.202214图示(2):男1男2女1女2女3返回X0=男2V1=男2V2 = T(V1)=女1Y=女1V1=男2,男1V2 =女1Y=女2MME(P)( 其中,P是从x0 y的可增广道路 ).11.09.202215匈牙利算法是基于Hall定理中充分性证明的思想,其基本步骤为:1任给初始匹配M; 2若X已饱和则结束,否则进行第3步; 3在X中找到一个非饱和顶点x0, 作V1 x0, V2 ; 4若T(V1) = V2则因为无法匹配而停止,否则任选一点y T(V1)V2; 5若y已饱和则转6,否则做一条从x

7、0 y的可增广道路P,MME(P),转2; 6由于y已饱和,所以M中有一条边(y,z),作 V1 V1 z, V2 V2 y, 转4; .11.09.202216图示(3):男1男2女1女2返回X0=男2V1=男2V2 = T(V1)=女1T(V1) != V2Y=女1V1=男2,男1V2 =女1T(V1)=V2.11.09.202217NOTE:真正求二分图的最大匹配的题目很少,往往做一些简单的变化,比如.11.09.202218变种1:二分图的最小顶点覆盖在二分图中求最少的点,让每条边都至少和其中的一个点关联,这就是“二分图的最小顶点覆盖”。.11.09.202219实 例 分 析.11.

8、09.202220例:严禁早恋,违者开除!男生女生.11.09.202221例:任务安排有两台机器A和B以及N个需要运行的任务。每台机器有M种不同的模式,而每个任务都恰好在一台机器上运行。如果它在机器A上运行,则机器A需要设置为模式ai,如果它在机器B上运行,则机器A需要设置为模式bi。每台机器上的任务可以按照任意顺序执行,但是每台机器每转换一次模式需要重启一次。请合理为每个任务安排一台机器并合理安排顺序,使得机器重启次数尽量少。hdoj_1150(LRJ_p331)ACM/ICPC Beijing 2002.11.09.202222图示:结论: 二分图的最小顶点覆盖数 = 二分图的最大匹配数

9、a0a1a2a3a4b0b1b2b3b4.11.09.202223特别说明:此题需要注意的一点,具体参见: /forum/read.php?tid=61&keyword=%B6%FE%B7%D6.11.09.202224变种2: DAG图的最小路径覆盖用尽量少的不相交简单路径覆盖有向无环图(DAG)G的所有顶点,这就是DAG图的最小路径覆盖问题。.11.09.202225例:空袭(Air Raid) 有一个城镇,它的所有街道都是单行的,并且每条街道都是和两个路口相连。同时已知街道不会形成回路。 你的任务是编写程序求最小数量的伞兵,这些伞兵可以访问(visit)所有的路口。对于伞兵的起始降落点不

10、做限制。hdoj_1151 .11.09.202226Sample input:433 41 32 3Output: 2.11.09.202227“空袭”示意图123443211324.11.09.202228结论:DAG图的最小路径覆盖数=节点数(n)- 最大匹配数(m)关键:求二分图的最大匹配数.11.09.202229变种3:二分图的最大独立集Girls and Boys 大学二年级的时候,一些同学开始研究男女同学之间的缘分。研究者试图找出没有缘分同学的最大集。程序的结果就是要输出这个集合中学生的数量。hdoj_1068 .11.09.202230输入数据格式: 70: (3) 4 5 61: (2) 4 62: (0)3: (0)4: (2) 0 15: (1) 06: (2) 0 1输出:5 .11.09.20223100154326543216“Girls and Boys”示意图.11.09.202232结论:二分图的最大独立集数=节点数(n) 最大匹配数(m)关键:求二分图的最大匹配数.11.09.202233Any Questions?.11.09.2022

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论