链接:点击打开链接
题意:求二分图最大匹配
代码:
#include <queue>
#include <vector>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <iostream>
#include <algorithm>
using namespace std;
vector<int> G[505];
int vis[505],fa[505];
int dfs(int S){
int i,v;
for(i=0;i<G[S].size();i++){
v=G[S][i];
if(vis[v]==0){
vis[v]=1;
if(fa[v]==-1||dfs(fa[v])){
fa[v]=S;
return 1;
}
}
}
return 0;
} //匈牙利算法模板题
int main(){
int k,m,n,i,u,v,ans;
while(scanf("%d",&k)!=EOF&&k){
scanf("%d%d",&n,&m);
for(i=1;i<=n;i++)
G[i].clear();
for(i=0;i<k;i++){
scanf("%d%d",&u,&v);
G[u].push_back(v);
}
memset(fa,-1,sizeof(fa));
ans=0;
for(i=1;i<=n;i++){
memset(vis,0,sizeof(vis));
if(dfs(i))
ans++;
}
printf("%d\n",ans);
}
return 0;
}