二分图最大匹配 匈牙利算法模板
2011-12-04 00:00
274 查看
二分图最大匹配问题的匈牙利算法: #include<iostream> using namespace std; const int Max = 405; int n, m; // 二分图中x和y中点的数目 int link[Max]; // link[x]记录当前与y节点相连的x的节点。 bool map[Max][Max], vis[Max]; // map[i][j]记录连接x和y的边,如果i和j之间有边则为1,否则为0。 bool dfs(int u){ // dfs实现,u表示现在在寻求匹配y的点x。 for(int i = 1; i <= m; i ++) if(!vis[i] && map[u][i]){ vis[i] = true; if(link[i] == -1 || dfs(link[i])){ // 条件:点i还没匹配,或者link[i]找到新的匹配。 link[i] = u; return true; } } return false; } int MaxMatch(){ int i,num = 0; memset(link, -1, sizeof(link)); for(i = 1;i <= n; i ++){ memset(vis, 0, sizeof(vis)); if(bfs(i)) num++; } return num; } |
相关文章推荐
- 二分图最大匹配之匈牙利算法模板
- POJ 1469 COURSES【匈牙利算法入门 二分图的最大匹配 模板题】
- hihocoder #1122 二分图二•二分图最大匹配之匈牙利算法(*【模板】应用 )
- (模板题)poj 3041 Asteroids(二分图的最大匹配匈牙利算法)
- 51Nod 飞行员配对(二分图最大匹配)(匈牙利算法模板题)
- 匈牙利算法模板 二分图最大匹配
- HDU 2444 The Accomodation of Students(最大二分匹配(匈牙利算法)+二分图判断->模板题目)
- 二分图最大匹配匈牙利算法模板两种
- 【匈牙利算法】二分图最大匹配(模板)
- 二分图最大匹配算法-匈牙利算法(Hungary)模板
- 匈牙利算法,二分图最大匹配、多重匹配模板
- 二分图最大匹配匈牙利算法(poj)3041(模板)
- NYOJ 题目239 月老的难题 (二分图最大匹配-匈牙利算法模板)
- 【模板】匈牙利算法——二分图最大匹配
- 二分图最大匹配 匈牙利算法 (自己写的模板)
- 透彻解析二分图最大匹配匈牙利算法模板
- 二分图最大匹配(匈牙利算法Dfs模板)
- [模板] + [详解] - 二分图最大匹配 - 匈牙利算法
- 二分图最大匹配(匈牙利算法-DFS增广模板)
- 二分图最大匹配模板(匈牙利算法)