![(HDUACM2010版-13)二分匹配及其應(yīng)用課件_第1頁(yè)](http://file4.renrendoc.com/view/3a390d9f5336dbca2da4433574e3ead2/3a390d9f5336dbca2da4433574e3ead21.gif)
![(HDUACM2010版-13)二分匹配及其應(yīng)用課件_第2頁(yè)](http://file4.renrendoc.com/view/3a390d9f5336dbca2da4433574e3ead2/3a390d9f5336dbca2da4433574e3ead22.gif)
![(HDUACM2010版-13)二分匹配及其應(yīng)用課件_第3頁(yè)](http://file4.renrendoc.com/view/3a390d9f5336dbca2da4433574e3ead2/3a390d9f5336dbca2da4433574e3ead23.gif)
![(HDUACM2010版-13)二分匹配及其應(yīng)用課件_第4頁(yè)](http://file4.renrendoc.com/view/3a390d9f5336dbca2da4433574e3ead2/3a390d9f5336dbca2da4433574e3ead24.gif)
![(HDUACM2010版-13)二分匹配及其應(yīng)用課件_第5頁(yè)](http://file4.renrendoc.com/view/3a390d9f5336dbca2da4433574e3ead2/3a390d9f5336dbca2da4433574e3ead25.gif)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
ACM程序設(shè)計(jì)(HDUACM2010版_13)二分匹配及其應(yīng)用今天,你開始了嗎?復(fù)習(xí)2023/11/182(HDUACM2010版_13)二分匹配及其應(yīng)用本周雙星(12):zhanlang2023/11/183(HDUACM2010版_13)二分匹配及其應(yīng)用第十三講二分圖及其應(yīng)用
(BipartiteGraph)2023/11/184(HDUACM2010版_13)二分匹配及其應(yīng)用主要內(nèi)容什么是二分圖二分圖的最大匹配匈牙利算法二分圖的最小頂點(diǎn)覆蓋DAG圖的最小路徑覆蓋二分圖的最大獨(dú)立集處理技巧2023/11/185(HDUACM2010版_13)二分匹配及其應(yīng)用什么是二分圖?如果一個(gè)圖的頂點(diǎn)可以分為兩個(gè)集合X和Y,圖的所有邊一定是有一個(gè)頂點(diǎn)屬于集合X,另一個(gè)頂點(diǎn)屬于集合Y,則稱該圖為“二分圖”(BipartiteGraph)2023/11/186(HDUACM2010版_13)二分匹配及其應(yīng)用例1:婚配問題男女2023/11/187(HDUACM2010版_13)二分匹配及其應(yīng)用二分圖的最大匹配 在二分圖的應(yīng)用中,最常見的就是最大匹配問題,很多其他的問題都可以通過轉(zhuǎn)化為匹配問題來解決。2023/11/188(HDUACM2010版_13)二分匹配及其應(yīng)用如何求二分圖的最大匹配呢?2023/11/189(HDUACM2010版_13)二分匹配及其應(yīng)用經(jīng)典算法:匈牙利算法2023/11/1810(HDUACM2010版_13)二分匹配及其應(yīng)用匈牙利算法(求二分圖最大匹配)談匈牙利算法自然避不開Hall定理Hall定理:對(duì)于二分圖G,存在一個(gè)匹配M,使得X的所有頂點(diǎn)關(guān)于M飽和的充要條件是:對(duì)于X的任意一個(gè)子集A,和A鄰接的點(diǎn)集為T(A),恒有:|T(A)|>=|A|
2023/11/1811(HDUACM2010版_13)二分匹配及其應(yīng)用圖示(1):男1男2女1女2女3返回2023/11/1812(HDUACM2010版_13)二分匹配及其應(yīng)用圖示(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)二分匹配及其應(yīng)用匈牙利算法——基本步驟:1.任給初始匹配M;2.若X已飽和則結(jié)束,否則進(jìn)行第3步;3.在X中找到一個(gè)非飽和頂點(diǎn)x0,作V1←{x0},V2←Φ;4.若T(V1)=V2則因?yàn)闊o法匹配而停止,否則任選一點(diǎn)y∈T(V1)\V2;5.若y已飽和則轉(zhuǎn)6,否則做一條從x0→y的可增廣道路P,M←M⊕E(P),轉(zhuǎn)2;6.由于y已飽和,所以M中有一條邊(y,z),作V1←V1∪{z},V2←V2∪{y},轉(zhuǎn)4;
2023/11/1814(HDUACM2010版_13)二分匹配及其應(yīng)用圖示(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)二分匹配及其應(yīng)用NOTE: 真正求二分圖的最大匹配的題目很少,往往做一些簡(jiǎn)單的變化,比如——2023/11/1816(HDUACM2010版_13)二分匹配及其應(yīng)用變種1:二分圖的最小頂點(diǎn)覆蓋 在二分圖中求最少的點(diǎn),讓每條邊都至少和其中的一個(gè)點(diǎn)關(guān)聯(lián),這就是
二分圖的“最小頂點(diǎn)覆蓋”。2023/11/1817(HDUACM2010版_13)二分匹配及其應(yīng)用實(shí)例分析2023/11/1818(HDUACM2010版_13)二分匹配及其應(yīng)用例2:嚴(yán)禁早戀,違者開除!男生女生2023/11/1819(HDUACM2010版_13)二分匹配及其應(yīng)用例3:HDOJ_1150任務(wù)安排
有兩臺(tái)機(jī)器A和B以及N個(gè)需要運(yùn)行的任務(wù)。每臺(tái)機(jī)器有M種不同的模式,而每個(gè)任務(wù)都恰好在一臺(tái)機(jī)器上運(yùn)行。如果它在機(jī)器A上運(yùn)行,則機(jī)器A需要設(shè)置為模式ai,如果它在機(jī)器B上運(yùn)行,則機(jī)器A需要設(shè)置為模式bi。每臺(tái)機(jī)器上的任務(wù)可以按照任意順序執(zhí)行,但是每臺(tái)機(jī)器每轉(zhuǎn)換一次模式需要重啟一次。請(qǐng)合理為每個(gè)任務(wù)安排一臺(tái)機(jī)器并合理安排順序,使得機(jī)器重啟次數(shù)盡量少?!狝CM/ICPCBeijing20022023/11/1820(HDUACM2010版_13)二分匹配及其應(yīng)用圖示:結(jié)論:二分圖的最小頂點(diǎn)覆蓋數(shù)=二分圖的最大匹配數(shù)a0a1a2a3a4b0b1b2b3b42023/11/1821(HDUACM2010版_13)二分匹配及其應(yīng)用特別說明:此題需要注意的一點(diǎn),具體參見:
/forum/read.php?tid=61&keyword=%B6%FE%B7%D62023/11/1822(HDUACM2010版_13)二分匹配及其應(yīng)用變種2:DAG圖的最小路徑覆蓋 用盡量少的不相交簡(jiǎn)單路徑覆蓋有向無環(huán)圖(DAG)G的所有頂點(diǎn),這就是DAG圖的最小路徑覆蓋問題。2023/11/1823(HDUACM2010版_13)二分匹配及其應(yīng)用例4:HDOJ_1151AirRaid 有一個(gè)城鎮(zhèn),它的所有街道都是單行的,并且每條街道都是和兩個(gè)路口相連。同時(shí)已知街道不會(huì)形成回路。 你的任務(wù)是編寫程序求最小數(shù)量的傘兵,這些傘兵可以訪問(visit)所有的路口。對(duì)于傘兵的起始降落點(diǎn)不做限制。2023/11/1824(HDUACM2010版_13)二分匹配及其應(yīng)用Input: 4
3
34
13
23Output:2樣本數(shù)據(jù):2023/11/1825(HDUACM2010版_13)二分匹配及其應(yīng)用“空襲”示意圖12344’3’2’1’13242023/11/1826(HDUACM2010版_13)二分匹配及其應(yīng)用結(jié)論:DAG圖的最小路徑覆蓋數(shù)=節(jié)點(diǎn)數(shù)(n)-最大匹配數(shù)(m)關(guān)鍵:求二分圖的最大匹配數(shù)2023/11/1827(HDUACM2010版_13)二分匹配及其應(yīng)用變種3:二分圖的最大獨(dú)立集HDOJ_1068GirlsandBoys
大學(xué)二年級(jí)的時(shí)候,一些同學(xué)開始研究男女同學(xué)之間的緣分。研究者試圖找出沒有緣分同學(xué)的最大集。程序的結(jié)果就是要輸出這個(gè)集合中學(xué)生的數(shù)量。2023/11/1828(HDUACM2010版_13)二分匹配及其應(yīng)用樣本數(shù)據(jù): 輸入:
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)二分匹配及其應(yīng)用00’154326’5’4’3’2’1’6“GirlsandBoys”示意圖2023/11/1830(HDUACM2010版_13)二分匹配及其應(yīng)用結(jié)論:二分圖的最大獨(dú)立集數(shù)=節(jié)點(diǎn)數(shù)(n)—最大匹配數(shù)(m)關(guān)鍵:求二分圖的最大匹配數(shù)2023/11/1831(HDUACM2010版_13)二分匹配及其應(yīng)用AnyQuestions?2023/11/1832(HDUACM2010版_13)二分匹配及其應(yīng)用相關(guān)練習(xí)201003《ACM程序設(shè)計(jì)》在線作業(yè)(13)——二分匹配2023/11/1833(HDUACM2010版_13)二分匹配及其應(yīng)用附:參考源碼(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等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 石化與化工工程作業(yè)指導(dǎo)書
- 建設(shè)工程材料居間合同
- 養(yǎng)殖類雇傭勞動(dòng)合同
- 裝修設(shè)計(jì)合同協(xié)議書
- 工程項(xiàng)目安全管理作業(yè)指導(dǎo)書
- 網(wǎng)站開發(fā)與維護(hù)技術(shù)作業(yè)指導(dǎo)書
- 夫妻離婚協(xié)議書標(biāo)準(zhǔn)格式
- 機(jī)械拆除承包合同
- 農(nóng)業(yè)與食品安全作業(yè)指導(dǎo)書
- 2025年株洲貨運(yùn)資格證題庫(kù)及答案大全
- 《管理學(xué)基礎(chǔ)》完整版課件全套ppt教程(最新)
- 短視頻:策劃+拍攝+制作+運(yùn)營(yíng)課件(完整版)
- 藍(lán)色卡通風(fēng)好書推薦教育PPT模板
- 2022年江蘇省泰州市中考數(shù)學(xué)試題及答案解析
- 石家莊鐵道大學(xué)四方學(xué)院畢業(yè)設(shè)計(jì)46
- 智能化系統(tǒng)培訓(xùn)
- 分布式光伏屋頂調(diào)查表
- 部編版五年級(jí)語(yǔ)文下冊(cè)第四單元課時(shí)作業(yè)本有答案
- 出國(guó)高中成績(jī)證明模板
- 高明---《琵琶記》解析課件.ppt
- 山嶺地承包合同書
評(píng)論
0/150
提交評(píng)論