- 1、本文档共35页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
(HDUACM2010版13)二分匹配及其应用7805287
ACM程序设计 杭州电子科技大学 刘春英 acm@ 今天, 你开始 了吗? 本周双星(12): 第十三讲 二分图及其应用(Bipartite Graph) 主要内容 什么是二分图 二分图的最大匹配 匈牙利算法 二分图的最小顶点覆盖 DAG图的最小路径覆盖 二分图的最大独立集 处理技巧 什么是二分图? 如果一个图的顶点可以分为两个集合X和Y,图的所有边一定是有一个顶点属于集合X,另一个顶点属于集合Y,则称该图为“二分图”( Bipartite Graph ) 例1:婚配问题 二分图的最大匹配 在二分图的应用中,最常见的就是最大匹配问题,很多其他的问题都可以通过转化为匹配问题来解决。 如何求二分图的最大匹配呢? 经典算法: 匈牙利算法 匈牙利算法(求二分图最大匹配) 谈匈牙利算法自然避不开Hall定理 Hall定理:对于二分图G,存在一个匹配M,使得X的所有顶点关于M饱和的充要条件是:对于X的任意一个子集A,和A邻接的点集为T(A),恒有: |T(A)| = |A| 图示(1): 图示(2): 匈牙利算法——基本步骤: 1.任给初始匹配M; 2.若X已饱和则结束,否则进行第3步; 3.在X中找到一个非饱和顶点x0, 作V1 ← {x0}, V2 ← Φ; 4.若T(V1) = V2则因为无法匹配而停止,否则任选一点y ∈T(V1)\V2; 5.若y已饱和则转6,否则做一条从x0 →y的可增广道路P,M←M⊕E(P),转2; 6.由于y已饱和,所以M中有一条边(y,z),作 V1 ← V1 ∪{z}, V2 ← V2 ∪ {y}, 转4; 图示(3): NOTE: 真正求二分图的最大匹配的题目很少,往往做一些简单的变化,比如—— 变种1:二分图的最小顶点覆盖 在二分图中求最少的点,让每条边都至少和其中的一个点关联,这就是 二分图的“最小顶点覆盖”。 实 例 分 析 例2:严禁早恋,违者开除! 例3:HDOJ_1150 任务安排 有两台机器A和B以及N个需要运行的任务。每台机器有M种不同的模式,而每个任务都恰好在一台机器上运行。如果它在机器A上运行,则机器A需要设置为模式ai,如果它在机器B上运行,则机器A需要设置为模式bi。每台机器上的任务可以按照任意顺序执行,但是每台机器每转换一次模式需要重启一次。请合理为每个任务安排一台机器并合理安排顺序,使得机器重启次数尽量少。 ——ACM/ICPC Beijing 2002 图示: 特别说明: 此题需要注意的一点,具体参见: /forum/read.php?tid=61keyword=%B6%FE%B7%D6 变种2:DAG图的最小路径覆盖 用尽量少的不相交简单路径覆盖有向无环图(DAG)G的所有顶点,这就是DAG图的最小路径覆盖问题。 例4:HDOJ_1151 Air Raid 有一个城镇,它的所有街道都是单行的,并且每条街道都是和两个路口相连。同时已知街道不会形成回路。 你的任务是编写程序求最小数量的伞兵,这些伞兵可以访问(visit)所有的路口。对于伞兵的起始降落点不做限制。 Input: 433 41 32 3 “空袭”示意图 结论: DAG图的最小路径覆盖数= 节点数(n)- 最大匹配数(m) 关键:求二分图的最大匹配数 变种3:二分图的最大独立集 HDOJ_1068 Girls and Boys 大学二年级的时候,一些同学开始研究男女同学之间的缘分。研究者试图找出没有缘分同学的最大集。程序的结果就是要输出这个集合中学生的数量。 样本数据: 输入: 70: (3) 4 5 61: (2) 4 62: (0)3: (0)4: (2) 0 15: (1) 06: (2) 0 1 “Girls and Boys”示意图 结论: 二分图的最大独立集数= 节点数(n)— 最大匹配数(m) 关键:求二分图的最大匹配数 Any Questions? 相关练习 201003《ACM程序设计》在线作业(13)—— 二分匹配 附:参考源码(HDOJ-1150) /*hdoj_1150匈牙利算法 月下版 */#includeiostream#includestring#includevectorusing namespace std;bool mark1[100],mark2[100];int list[100];int n,m,edge,num;vectorvectorint v;bool dfs(int to){register int i,point,s = list[to];for(i=0;iv[s].size();i++){point = v[s]
您可能关注的文档
- (2015年PPT模板)华夏地理08作品_经典排版.ppt
- (2015中考精英)2015中考英语人教版复习课件:第18讲 九年级Units 9~10.ppt
- (2012年新版)人教新目标七年级英语下册《Unit6 I’m watching TV Section A》优秀课件.ppt
- (2012读者培训)全文文献获取的方法与期刊等级鉴别.ppt
- (2012年新版)《Unit6_I’m_watching_TV_Section_A》优秀课件.ppt
- (Antonymy) 反义词.ppt
- (C)2 水处理-2.ppt
- (Book 1)英语写作4-6单元(195页)(2012.12.20).ppt
- (2015年PPT模板)Conference Sample Slides.ppt
- (EndNote)journals list-5776文献 全称-缩写带点和不带点.docx
- 6.3.1 种群基因组成的变化课件(共54张PPT)--下学期高一生物(人教版)必修2.pptx
- 6.3.2分数加减混合运算(2)(教学课件)(共20张PPT)——小学数学人教版五年级下册.pptx
- 9.2图形与几何(教学课件)(共22张PPT)——小学数学人教版五年级下册.pptx
- 5.1植物生长素(下)课件(共46张PPT,内嵌视频) 人教版(2019)高中生物学选择性必修1.pptx
- 9.3总复习(3)课件(共24张PPT)——小学数学人教版五年级下册.pptx
- 1.3 学会自我保护 教学课件(共21张PPT)+内嵌视频-初中统编版(2024)道德与法治七 年级下册.pptx
- 15.1 谏太宗十思疏课件(共33张PPT)统编版高中语文必修下册.pptx
- 12.《祝福》课件(共31张PPT)统编版高中语文必修下册.ppt
- 《登岳阳楼》课件统编版高一语文必修下册.pptx
- 航空发动机孔探诊断技术应用研究.docx
最近下载
- (正式版)D-L∕T 860.74-2014 电力自动化通信网络和系统 第7-4部分:基本通信结构 兼容逻辑节点类和数据类.docx VIP
- 钢格栅板及配套件国家标准.pdf
- 防火墙运维.docx VIP
- T_BPMA 0010—2021_现制现售净水机卫生管理规范.pdf VIP
- 有害物质识别与评估控制程序.doc VIP
- 胃脘痛•胃痞病(胃息肉)中医临床路径标准住院表单.docx VIP
- JAVA应用系统开发规范概要1.doc VIP
- 临床诊疗指南(肿瘤科分册).doc
- 剑桥少儿英语一级上unit15_a_happy_new_year.ppt VIP
- 2024年05月广东惠州市生态环境局博罗分局和博罗县污染防治攻坚战总指挥部办公室公开招聘编外人员笔试历年典型题及考点剖析附带答案含详解.docx VIP
文档评论(0)