二分圖匹配實(shí)例代碼及整理
二分圖匹配實(shí)例代碼及整理
1、匈牙利算法
HDU 1150
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
int m,n,k;
int vis[105];
int mpt[105][105];
int use[105];
int hungary(int x)
{
for(int i=1;i<m;i++)
{
if(vis[i]==0&&mpt[x][i]==1)
{
vis[i]=1;
if(use[i]==-1||hungary(use[i]))
{
use[i]=x;
return 1;
}
}
}
return 0;
}
int main()
{
while(scanf("%d",&n)!=EOF,n)
{
scanf("%d%d",&m,&k);
int a,b,c;
memset(mpt,0,sizeof(mpt));
for(int i=1;i<=k;i++)
{
scanf("%d%d%d",&c,&a,&b);
mpt[a][b]=1;
}
int ans=0;
memset(use,-1,sizeof(use));
for(int i=1;i<n;i++)
{
if(hungary(i))
{
ans++;
}
memset(vis,0,sizeof(vis));
}
printf("%d\n",ans);
}
return 0;
}
2、KM算法
HDU 2255
看了很多資料都還不是很懂、、先貼別人的模板
#include<iostream>
#include<cstdio>
#include<cstring>
#include<climits>
#include<algorithm>
using namespace std;
#define N 310
int map[N][N];
bool visitx[N], visity[N];
int lx[N], ly[N];
int match[N];
int n;
bool Hungary(int u) //匈牙利算法
{
visitx[u] = true;
for(int i = 0; i < n; ++i)
{
if(!visity[i] && lx[u] + ly[i] == map[u][i])
{
visity[i] = true;
if(match[i] == -1 || Hungary(match[i]))
{
match[i] = u;
return true;
}
}
}
return false;
}
void KM_perfect_match()
{
int temp;
memset(lx, 0, sizeof(lx)); //初始化頂標(biāo)
memset(ly, 0, sizeof(ly)); //ly[i]為0
for(int i = 0; i < n; ++i) //lx[i]為權(quán)值最大的邊
for(int j = 0; j < n; ++j)
lx[i] = max(lx[i], map[i][j]);
for(int i = 0; i < n; ++i) //對(duì)n個(gè)點(diǎn)匹配
{
while(1)
{
memset(visitx, false, sizeof(visitx));
memset(visity, false, sizeof(visity));
if(Hungary(i)) //匹配成功
break;
else //匹配失敗,找最小值
{
temp = INT_MAX;
for(int j = 0; j < n; ++j) //x在交錯(cuò)樹中
if(visitx[j])
for(int k = 0; k < n; ++k) //y在交錯(cuò)樹外
if(!visity[k] && temp > lx[j] + ly[k] - map[j][k])
temp = lx[j] + ly[k] - map[j][k];
for(int j = 0; j < n; ++j) //更新頂標(biāo)
{
if(visitx[j])
lx[j] -= temp;
if(visity[j])
ly[j] += temp;
}
}
}
}
}
int main()
{
int ans;
while(scanf("%d", &n) != EOF)
{
ans = 0;
memset(match, -1, sizeof(match));
for(int i = 0; i < n; ++i)
for(int j = 0; j < n; ++j)
scanf("%d", &map[i][j]);
KM_perfect_match();
for(int i = 0; i < n; ++i) //權(quán)值相加
ans += map[match[i]][i];
printf("%d\n", ans);
}
return 0;
}
3、多重匹配
HDU 3605 Escape
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
int n,m;
int num[15];
int mpt[100005][15];
int vis[15];
int use[15];
int dp[15][100005];
int hungary(int x)
{
for(int i=1;i<=m;i++)
{
if(vis[i]==0&&mpt[x][i]==1)
{
vis[i]=1;
if(use[i]<num[i])//滿足條件
{
dp[i][use[i]++]=x;
return 1;
}
//不滿足則尋找增廣路
for(int j=0;j<use[i];j++)//看能否回溯一個(gè)出去
{
if(hungary(dp[i][j]))
{
dp[i][j]=x;
return 1;
}
}
}
}
return 0;
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
scanf("%d",&mpt[i][j]);
}
}
for(int i=1;i<=m;i++)
scanf("%d",&num[i]);
int ans=0;
memset(use,0,sizeof(use));
for(int i=1;i<=n;i++)
{
memset(vis,0,sizeof(vis));
if(!hungary(i))
{
ans=1;
break;
}
}
if(ans==0)
{
printf("YES\n");
}
else printf("NO\n");
}
return 0;
}
以上就是二分圖匹配的實(shí)現(xiàn)代碼,如有疑問請(qǐng)留言,或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
opencv3/C++ 實(shí)現(xiàn)SURF特征檢測(cè)
今天小編就為大家分享一篇opencv3/C++ 實(shí)現(xiàn)SURF特征檢測(cè),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12
C語言實(shí)現(xiàn)紅黑樹詳細(xì)步驟+代碼
大家好,本篇文章主要講的是C語言實(shí)現(xiàn)紅黑樹詳細(xì)步驟+代碼,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01
C++實(shí)現(xiàn)的多重繼承功能簡(jiǎn)單示例
這篇文章主要介紹了C++實(shí)現(xiàn)的多重繼承功能,結(jié)合簡(jiǎn)單實(shí)例形式分析了C++面向?qū)ο蟪绦蛟O(shè)計(jì)中類的定義與繼承相關(guān)操作實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-05-05
重啟后nvidia-smi命令不可執(zhí)行出現(xiàn)“Make?sure?that?the?latest?NVIDIA?
這篇文章主要介紹了重啟后nvidia-smi命令不可執(zhí)行,出現(xiàn)“Make?sure?that?the?latest?NVIDIA?driver?is?installed?and?running.”問題,本文給大家分享最新完美解決方法,需要的朋友可以參考下2022-12-12
線程崩潰不會(huì)導(dǎo)致?JVM?崩潰的原因解析
網(wǎng)上看到一個(gè)很有意思的據(jù)說是美團(tuán)的面試題:為什么線程崩潰崩潰不會(huì)導(dǎo)致?JVM?崩潰,這個(gè)問題我看了不少回答,但都沒答到根本原因,所以決定答一答,相信大家看完肯定會(huì)有收獲,本文分以下幾節(jié)來探討,需要的朋友可以參考下2022-06-06
C++實(shí)現(xiàn)簡(jiǎn)易選課系統(tǒng)代碼分享
這篇文章主要介紹了C++實(shí)現(xiàn)簡(jiǎn)易選課系統(tǒng)及實(shí)現(xiàn)代碼的分享,具有一定的參考價(jià)值,需要的小伙伴可以參考一下,希望對(duì)你有所幫助2022-01-01
VScode + keil開發(fā)環(huán)境搭建安裝使用過程
這篇文章主要介紹了VScode + keil開發(fā)環(huán)境搭建及安裝使用過程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-07-07

