二分圖匹配實例代碼及整理
二分圖匹配實例代碼及整理
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)); //初始化頂標 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) //對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在交錯樹中 if(visitx[j]) for(int k = 0; k < n; ++k) //y在交錯樹外 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) //更新頂標 { 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++)//看能否回溯一個出去 { 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; }
以上就是二分圖匹配的實現(xiàn)代碼,如有疑問請留言,或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
欄 目:C語言
下一篇:C/C++ 數(shù)組和指針及引用的區(qū)別
本文標題:二分圖匹配實例代碼及整理
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1322.html
您可能感興趣的文章
- 04-02c語言的正則匹配函數(shù) c語言正則表達式函數(shù)庫
- 01-10快速模式匹配算法(KMP)的深入理解
- 01-10深入串的模式匹配算法(普通算法和KMP算法)的詳解
- 01-10libxml教程(圖文詳解)
- 01-10用代碼和UML圖化解設計模式之橋接模式的深入分析
- 01-10c++ 構(gòu)造函數(shù)的初始化列表
- 01-10VC實現(xiàn)圖片拖拽及動畫的實例
- 01-10c語言常見圖片格式判斷實例
- 01-10C語言使用stdlib.h庫函數(shù)的二分查找和快速排序的實現(xiàn)代碼
- 01-10用位圖排序無重復數(shù)據(jù)集實例代碼(C++版)


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機閱讀
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10C#中split用法實例總結(jié)
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery