过山车 HDU 2063 (二分图匹配裸题)
1<=N 和M<=500.接下来的K行,每行有两个数,分别表示女生Ai愿意和男生Bj做partner。最后一个0结束输入。
#include<cstdio>
#include<cstring>
#include<algorithm>
#define MAXN 510
using namespace std;
int n,m,k;///x,y集合中点的个数
int maps[MAXN][MAXN];///邻接矩阵
int cx[MAXN];///匹配关系,cx[1]=2表示男1和女2约会
int cy[MAXN];
int vis[MAXN];///顶点访问状态数组,1访问过,0未访问过
int path(int x)///x为任何一个女生
{
int i;
for(i=; i<=n; i++)///i为男生
{
if(maps[x][i]&&!vis[i])
{
vis[i]=;
if(!cx[i]||path(cx[i]))
{
cx[i]=x;
cy[x]=i;
return ;
}
}
}
return ;
}
int MaxMatch()
{
int res=;
int i;
memset(cy,,sizeof(cy));
memset(cx,,sizeof(cx));///初始化为0
for(i=; i<=m; i++)
{
memset(vis,,sizeof(vis));
if(path(i))
{
res++;
}
}
return res;
}
int main()
{
int i;
int a,b;
while(scanf("%d",&k)!=EOF)
{
if(k==)
{
break;
}
scanf("%d%d",&m,&n);
memset(maps,,sizeof(maps));
for(i=; i<k; i++)
{
scanf("%d%d",&a,&b);
maps[a][b]=;
}
printf("%d\n",MaxMatch());
}
return ;
}
BFS实现:
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define MAXN 510
using namespace std;
int nx,ny;///x,y集合中点的个数
int maps[MAXN][MAXN];///邻接矩阵
int cx[MAXN],cy[MAXN];///cx[i]表示最终求得的最大匹配中与xi匹配的Y节点
int pre[MAXN];///x每一个点的上一个节点
int vis[MAXN];///标志一个点在找增广路的同时是否被访问过
int MaxMatch()
{
int i,j,y;
int res=;///所求得的最大匹配数
memset(cx,,sizeof(cx));
memset(cy,,sizeof(cy));
memset(vis,,sizeof(vis));
for(i=; i<=nx; i++)
{
if(!cx[i])
{
queue<int>q;
q.push(i);
pre[i]=-;
int flag=;///标志是否找到了增广路
while(!q.empty()&&!flag)
{
int u=q.front();
q.pop();
for(int v=; v<=ny&&!flag; v++)
{
if(maps[u][v]&&vis[v]!=i)
{
vis[v]=i;
q.push(cy[v]);///将于y匹配的x点放入队列
if(cy[v]!=)///没有增广路
{
pre[cy[v]]=u;///记录x点的顺序
}
else///找到增广路
{
flag=;
int d=u,e=v;
while(d!=-)///将原来匹配的边去掉加入原来不在匹配中的边
{
int t=cx[d];
cx[d]=e;
cy[e]=d;
d=pre[d];
e=t;
}
}
}
}
}
if(cx[i]!=)///新增一个匹配的边
{
res++;
}
}
}
return res;
}
int main()
{
int i;
int a,b;
int k;
while(scanf("%d",&k)!=EOF)
{
if(k==)
{
break;
}
scanf("%d%d",&nx,&ny);
memset(maps,,sizeof(maps));
for(i=; i<k; i++)
{
scanf("%d%d",&a,&b);
maps[a][b]=;
}
printf("%d\n",MaxMatch());
}
return ;
}
过山车 HDU 2063 (二分图匹配裸题)的更多相关文章
- (二分匹配 模板)过山车 -- hdu --2063
链接: http://acm.hdu.edu.cn/showproblem.php?pid=2063 http://acm.hust.edu.cn/vjudge/contest/view.action ...
- hdu 2063 二分图匹配
题意:一些女的和一些男的有好感,有好感的能一起坐过山车,问最多能组成多少对 hdu 11 页上少有的算法题,二分图匹配问题,匈牙利算法,对于每一个汉子,看和他有好感的妹子有没有配对了,没有配对过就可以 ...
- HDU 2063 过山车(模板—— 二分图最大匹配问题)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2063 解题思路: 二分图最大匹配模板题. AC代码: #include<stdio.h> ...
- hdu 1281 二分图匹配
题目:在保证尽量多的“车”的前提下,棋盘里有些格子是可以避开的,也就是说,不在这些格子上放车,也可以保证尽量多的“车”被放下.但是某些格子若不放子,就 无法保证放尽量多的“车”,这样的格子被称做重要点 ...
- hdu 4185 二分图匹配
题意用1*2的木板覆盖矩阵中的‘#’,(木板要覆盖的只能是‘#’),问最多能用几个木板覆盖 将#抽象为二分图的点,一个木板就是一个匹配,注意最后结果要除以2 Sample Input 1 6 .... ...
- hdu 1507(二分图匹配)
Uncle Tom's Inherited Land* Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (J ...
- Land of Farms HDU - 5556 二分图匹配
Farmer John and his brothers have found a new land. They are so excited and decide to build new farm ...
- HDU——2444The Accomodation of Students(BFS判二分图+最大匹配裸题)
The Accomodation of Students Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K ( ...
- Fire Net HDU - 1045 (二分图匹配)
题意: 给出一张图,图中'X'表示wall,'.'表示空地,可以放置blockhouse同一条直线上只能有一个blockhouse,除非有wall 隔开,问在给出的图中最多能放置多少个blockhou ...
随机推荐
- 【Linux】管理文件系统
文件系统概念: 文件系统是指文件的组织与管理结构,是一个有关于磁盘中各种有用信息的记录——即是保存以下信息的结构记录表 当前所使用磁盘的容量信息 磁盘的可用信息,包括已占用和剩余的空间: 文件与目录的 ...
- 基于 HTML5 WebGL 的 3D 水泥工厂生产线
前言 今天为大家带来一个很酷的作品,依然运用了强大的 HT for Web 的 3D 图形组件,动作流畅性能好,大家可以先来欣赏一下效果! 点我进入! 整体风格为科技金属风,制作精良,由于上传 gif ...
- Linuxg环境搭建
1.使用VMWARE软件安装虚拟机,创建打开将进入桌面. 2.配置静态IP.IP环境关系到能否使用网络进行软件的下载,即apt的使用. 1).找到文件并作如下修改:sudo vim /etc/netw ...
- Spark SQL join的三种实现方式
引言 join是SQL中的常用操作,良好的表结构能够将数据分散到不同的表中,使其符合某种规范(mysql三大范式),可以最大程度的减少数据冗余,更新容错等,而建立表和表之间关系的最佳方式就是join操 ...
- elasticsearch_dsl 的nested
在工作中会碰到这样的一个需求,mapping中定义的类型是nested { "judgement":{ "mappings":{ "content&q ...
- 《你不知道的JavaScript》系列分享专栏
<你不知道的JavaScript>系列分享专栏 你不知道的JavaScript”系列就是要让不求甚解的JavaScript开发者迎难而上,深入语言内部,弄清楚JavaScript每一个零部 ...
- java的三个体系
Java是由SunMicrosystems公司于1995年5月推出的Java面向对象程序设计语言和Java平台的总称.由JamesGosling和同事们共同研发,并在1995年正式推出. Java分为 ...
- 20155224聂小益 2016-2017-2 《Java程序设计》第1周学习总结
20155224聂小益 2016-2017-2 <Java程序设计>第1周学习总结 教材学习内容总结 第一章 第一章内容不是很多,主要介绍了Java发展历程与Java的使用平台. JVM: ...
- day 3 私有属性,私有方法,__del__
1.隐藏对象的属性 如果有一个对象,当需要对其进行修改属性时,有2种方法 对象名.属性名 = 数据 ---->直接修改 对象名.方法名() ---->间接修改 1)版本1:直接修改 对象的 ...
- 16、Java并发编程:Timer和TimerTask
Java并发编程:Timer和TimerTask(转载) 下面内容转载自: http://blog.csdn.net/xieyuooo/article/details/8607220 其实就Timer ...