您的位置:首页 > Web前端

Ural-1109-Conference

2013-02-27 17:07 441 查看
比较简单的2分图匹配题,用匈牙利法做就OK吧,第一次做类似的题

代码:

#include<cstdio>
#include<cstring>
#define MAX 1001
int n,m,k,pre[MAX],map[MAX][MAX],vis[MAX];
bool dfs(int x)
{
for(int i=1;i<=m;i++)
{
if(!vis[i]&&map[x][i])
{
vis[i]=1;
if(!pre[i]||dfs(pre[i]))
{
pre[i]=x;
return true;
}
}
}
return false;
}
int main()
{
while(scanf("%d%d%d",&n,&m,&k)!=EOF)
{
for(int i=0;i<k;i++)
{
int ita,itb;
scanf("%d%d",&ita,&itb);
map[ita][itb]=1;
}
int ans=0;
for(int i=1;i<=n;i++)
{
memset(vis,0,sizeof(vis));
if(dfs(i))
ans++;
}
printf("%d\n",n+m-ans);
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: