【匈牙利算法】 二分图模板 poj 1274
2014-10-10 10:47
483 查看
#include <iostream> #include <cstdio> #include <memory.h> using namespace std; int n,m,num,temp,sum; int re[201][201],link[201];//牛与牛栏的对应关系 bool tag[201];//增益路径 bool DFS(int a) { for(int i=1;i<=m;i++) { if(re[a][i]!=0 && !tag[i])//如果节点i与a相邻并且未被查找过 { tag[i]=true;//标记i为已查找过 if(link[i]==-1||DFS(link[i]))//i在匹配M中,但是从与i相邻的节点出发可以有增广路 { link[i]=a;//记录查找成功记录 // cout << "sucess i=" << i << " link[i]= "<<link[i] <<endl; return true;//返回查找成功 } } } return false; } int main() { //freopen("in.txt","r",stdin); while(cin>>n>>m) // cow stall { int i,j,sum=0; memset(re,0,sizeof(re)); memset(link,-1,sizeof(link)); for(i=1;i<=n;i++) { cin>>num; for(j=1;j<=num;j++) { cin>>temp; re[i][temp]=1; } }//初始化 for(i=1;i<=n;i++) //cow { for(j=1;j<=m;j++) //stall { tag[j]=false; } if(DFS(i))//从节点i尝试扩展 sum++; } cout << sum << endl; } return 0; }
相关文章推荐
- (模板题)poj 3041 Asteroids(二分图的最大匹配匈牙利算法)
- POJ1274:The Perfect Stall(二分图最大匹配 匈牙利算法)
- POJ1274 The Perfect Stall [二分图最大匹配 匈牙利算法]
- poj 1274 最大流或二分图,匈牙利算法
- POJ 1325 && 1274:Machine Schedule 匈牙利算法模板题
- POJ 1469 COURSES【匈牙利算法入门 二分图的最大匹配 模板题】
- poj-1469,1274 二分图匈牙利算法
- POJ 1325 && 1274:Machine Schedule 匈牙利算法模板题
- POJ 1274 The Perfect Stall (匈牙利算法模板)
- POJ 1274 The Perfect Stall(匈牙利算法模板)
- POJ 1469 COURSES【匈牙利算法入门 二分图的最大匹配 模板题】
- POJ 1469,1274,2239,2536,2584,2446二分图的匈牙利算法(裸)
- poj 1274 The Perfect Stall(匈牙利算法模板)
- poj 1274 The Perfect Stall【匈牙利算法模板题】
- POJ 1274 The Perfect Stall (二分图最大匹配入门题,匈牙利算法)
- POJ1274:The Perfect Stall(二分图最大匹配 匈牙利算法)
- 二分图最大匹配匈牙利算法(poj)3041(模板)
- poj 3894 System Engineer (二分图最大匹配--匈牙利算法)
- 二分图最大匹配 匈牙利算法 (自己写的模板)
- HDU 2444 The Accomodation of Students(最大二分匹配(匈牙利算法)+二分图判断->模板题目)