(HDUACM2010版-13)二分匹配及其应用课件_第1页
(HDUACM2010版-13)二分匹配及其应用课件_第2页
(HDUACM2010版-13)二分匹配及其应用课件_第3页
(HDUACM2010版-13)二分匹配及其应用课件_第4页
(HDUACM2010版-13)二分匹配及其应用课件_第5页
已阅读5页,还剩31页未读 继续免费阅读

下载本文档

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

文档简介

ACM程序设计(HDUACM2010版_13)二分匹配及其应用今天,你开始了吗?复习2023/11/182(HDUACM2010版_13)二分匹配及其应用本周双星(12):zhanlang2023/11/183(HDUACM2010版_13)二分匹配及其应用第十三讲二分图及其应用

(BipartiteGraph)2023/11/184(HDUACM2010版_13)二分匹配及其应用主要内容什么是二分图二分图的最大匹配匈牙利算法二分图的最小顶点覆盖DAG图的最小路径覆盖二分图的最大独立集处理技巧2023/11/185(HDUACM2010版_13)二分匹配及其应用什么是二分图?如果一个图的顶点可以分为两个集合X和Y,图的所有边一定是有一个顶点属于集合X,另一个顶点属于集合Y,则称该图为“二分图”(BipartiteGraph)2023/11/186(HDUACM2010版_13)二分匹配及其应用例1:婚配问题男女2023/11/187(HDUACM2010版_13)二分匹配及其应用二分图的最大匹配 在二分图的应用中,最常见的就是最大匹配问题,很多其他的问题都可以通过转化为匹配问题来解决。2023/11/188(HDUACM2010版_13)二分匹配及其应用如何求二分图的最大匹配呢?2023/11/189(HDUACM2010版_13)二分匹配及其应用经典算法:匈牙利算法2023/11/1810(HDUACM2010版_13)二分匹配及其应用匈牙利算法(求二分图最大匹配)谈匈牙利算法自然避不开Hall定理Hall定理:对于二分图G,存在一个匹配M,使得X的所有顶点关于M饱和的充要条件是:对于X的任意一个子集A,和A邻接的点集为T(A),恒有:|T(A)|>=|A|

2023/11/1811(HDUACM2010版_13)二分匹配及其应用图示(1):男1男2女1女2女3返回2023/11/1812(HDUACM2010版_13)二分匹配及其应用图示(2):男1男2女1女2女3返回X0=男2V1={男2}V2=ΦT(V1)={女1}Y=女1V1={男2,男1}V2={女1}Y=女2M←M⊕E(P)(其中,P是从x0→y的可增广道路)2023/11/1813(HDUACM2010版_13)二分匹配及其应用匈牙利算法——基本步骤: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;

2023/11/1814(HDUACM2010版_13)二分匹配及其应用图示(3):男1男2女1女2返回X0=男2V1={男2}V2=ΦT(V1)={女1}T(V1)!=V2Y=女1V1={男2,男1}V2={女1}T(V1)=V22023/11/1815(HDUACM2010版_13)二分匹配及其应用NOTE: 真正求二分图的最大匹配的题目很少,往往做一些简单的变化,比如——2023/11/1816(HDUACM2010版_13)二分匹配及其应用变种1:二分图的最小顶点覆盖 在二分图中求最少的点,让每条边都至少和其中的一个点关联,这就是

二分图的“最小顶点覆盖”。2023/11/1817(HDUACM2010版_13)二分匹配及其应用实例分析2023/11/1818(HDUACM2010版_13)二分匹配及其应用例2:严禁早恋,违者开除!男生女生2023/11/1819(HDUACM2010版_13)二分匹配及其应用例3:HDOJ_1150任务安排

有两台机器A和B以及N个需要运行的任务。每台机器有M种不同的模式,而每个任务都恰好在一台机器上运行。如果它在机器A上运行,则机器A需要设置为模式ai,如果它在机器B上运行,则机器A需要设置为模式bi。每台机器上的任务可以按照任意顺序执行,但是每台机器每转换一次模式需要重启一次。请合理为每个任务安排一台机器并合理安排顺序,使得机器重启次数尽量少。——ACM/ICPCBeijing20022023/11/1820(HDUACM2010版_13)二分匹配及其应用图示:结论:二分图的最小顶点覆盖数=二分图的最大匹配数a0a1a2a3a4b0b1b2b3b42023/11/1821(HDUACM2010版_13)二分匹配及其应用特别说明:此题需要注意的一点,具体参见:

/forum/read.php?tid=61&keyword=%B6%FE%B7%D62023/11/1822(HDUACM2010版_13)二分匹配及其应用变种2:DAG图的最小路径覆盖 用尽量少的不相交简单路径覆盖有向无环图(DAG)G的所有顶点,这就是DAG图的最小路径覆盖问题。2023/11/1823(HDUACM2010版_13)二分匹配及其应用例4:HDOJ_1151AirRaid 有一个城镇,它的所有街道都是单行的,并且每条街道都是和两个路口相连。同时已知街道不会形成回路。 你的任务是编写程序求最小数量的伞兵,这些伞兵可以访问(visit)所有的路口。对于伞兵的起始降落点不做限制。2023/11/1824(HDUACM2010版_13)二分匹配及其应用Input: 4

3

34

13

23Output:2样本数据:2023/11/1825(HDUACM2010版_13)二分匹配及其应用“空袭”示意图12344’3’2’1’13242023/11/1826(HDUACM2010版_13)二分匹配及其应用结论:DAG图的最小路径覆盖数=节点数(n)-最大匹配数(m)关键:求二分图的最大匹配数2023/11/1827(HDUACM2010版_13)二分匹配及其应用变种3:二分图的最大独立集HDOJ_1068GirlsandBoys

大学二年级的时候,一些同学开始研究男女同学之间的缘分。研究者试图找出没有缘分同学的最大集。程序的结果就是要输出这个集合中学生的数量。2023/11/1828(HDUACM2010版_13)二分匹配及其应用样本数据: 输入:

7

0:(3)456

1:(2)46

2:(0)

3:(0)

4:(2)01

5:(1)0

6:(2)01输出:5

2023/11/1829(HDUACM2010版_13)二分匹配及其应用00’154326’5’4’3’2’1’6“GirlsandBoys”示意图2023/11/1830(HDUACM2010版_13)二分匹配及其应用结论:二分图的最大独立集数=节点数(n)—最大匹配数(m)关键:求二分图的最大匹配数2023/11/1831(HDUACM2010版_13)二分匹配及其应用AnyQuestions?2023/11/1832(HDUACM2010版_13)二分匹配及其应用相关练习201003《ACM程序设计》在线作业(13)——二分匹配2023/11/1833(HDUACM2010版_13)二分匹配及其应用附:参考源码(HDOJ-1150)/*hdoj_1150匈牙利算法月下版*/

#include<iostream>

#include<string>

#include<vector>

usingnamespacestd;

boolmark1[100],mark2[100];

intlist[100];

intn,m,edge,num;

vector<vector<int>>v;

booldfs(intto)

{

registerinti,point,s=list[to];

for(i=0;i<v[s].size();i++)

{

point=v[s][i];

if(!mark2[point])

continue;

mark2[point]=false;

if(list[point]==-1||dfs(point)){

list[point]=s;

returntrue;

}

}

returnfalse;

}

voidSolve()

{

inti,j,point;

boolflog=false;

memset(mark1,true,sizeof(mark1));

memset(list,-1,sizeof(list));

num=0;

for(i=0;i<n;i++)

{

for(j=0;j<v[i].size();j++)

if(list[v[i][j]]==-1)

{

mark1[i]=false;

list[v[i][j]]=i;

num++;

if(i==0)flog=true;

break;

}

}for(i=0;i<n;i++)

{

if(mark1[i])

{

if(!v[i].empty()){

memset(mark2,true,sizeof(mark2));

for(j=0;j<v[i].size();j++)

{

point=v[i][j];

if(!mark2[point])continue;

mark2[point]=false;

if(list[point]==-1||dfs(point))

{

list[point]=i;

num++;

break;

}

}

}

mark1[i]=false;

}

}

if(flog||list[0]!=-1)

cout<<num-1<<endl;

elsecout<<num<<endl;

}

intmain()

{

inti,j,s,d;

while(cin>>n)

{

if(n==0)break;

v.clear();

v.resize(n);

cin>>

温馨提示

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

评论

0/150

提交评论