二分图匹配实例代码及整理

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]为权值最大的边
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) //权值相加
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;
}
以上就是二分图匹配的实现代码,如有疑问请留言,或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# 二分图匹配
# 二分图匹配的实例
# 匈牙利
# 看了
# 如有
# 不是很
# 希望能
# 谢谢大家
# 都还
# 不满足
# 疑问请
# 最小值
# main
# amp
# return
# vis
# hungary
# mpt
# ans
# printf
# br
# sizeof
相关文章:
在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
测试制作网站有哪些,测试性取向的权威测试或者网站?
制作网站的模板软件,网站怎么建设?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
个人摄影网站制作流程,摄影爱好者都去什么网站?
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
建站主机选购指南:核心配置与性价比推荐解析
香港服务器部署网站为何提示未备案?
制作农业网站的软件,比较好的农业网站推荐一下?
如何在建站宝盒中设置产品搜索功能?
建站主机SSH密钥生成步骤及常见问题解答?
南宁网站建设制作定制,南宁网站建设可以定制吗?
如何批量查询域名的建站时间记录?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
如何快速搭建虚拟主机网站?新手必看指南
建站之星2.7模板:企业网站建设与h5定制设计专题
建站之星伪静态规则如何正确配置?
如何高效生成建站之星成品网站源码?
如何自定义建站之星模板颜色并下载新样式?
,巨量百应是干嘛的?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
行程制作网站有哪些,第三方机票电子行程单怎么开?
如何在阿里云购买域名并搭建网站?
常州自助建站:操作简便模板丰富,企业个人快速搭建网站
大同网页,大同瑞慈医院官网?
广平建站公司哪家专业可靠?如何选择?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
javascript基本数据类型及类型检测常用方法小结
宝塔新建站点为何无法访问?如何排查?
存储型VPS适合搭建中小型网站吗?
企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?
开心动漫网站制作软件下载,十分开心动画为何停播?
网站设计制作公司地址,网站建设比较好的公司都有哪些?
免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?
如何快速打造个性化非模板自助建站?
天津个人网站制作公司,天津网约车驾驶员从业资格证官网?
济南网站制作的价格,历城一职专官方网站?
官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站
如何选择域名并搭建高效网站?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
建站之星如何实现网站加密操作?
北京的网站制作公司有哪些,哪个视频网站最好?
建站之星安装失败:服务器环境不兼容?
如何在企业微信快速生成手机电脑官网?
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
Swift开发中switch语句值绑定模式
潮流网站制作头像软件下载,适合母子的网名有哪些?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
*请认真填写需求信息,我们会在24小时内与您取得联系。