Problem Description
RPG girls今天和大家一起去游乐场玩,终于可以坐上梦寐以求的过山车了。可是,过山车的每一排只有两个座位,而且还有条不成文的规矩,就是每个女生必须找个个男生做partner和她同坐。但是,每个女孩都有各自的想法,举个例子把,Rabbit只愿意和XHD或PQK做partner,Grass只愿意和linle或LL做partner,PrincessSnow愿意和水域浪子或伪酷儿做partner。考虑到经费问题,boss刘决定只让找到partner的人去坐过山车,其他的人,嘿嘿,就站在下面看着吧。聪明的Acmer,你可以帮忙算算最多有多少对组合可以坐上过山车吗?
 
Input
输入数据的第一行是三个整数K , M , N,分别表示可能的组合数目,女生的人数,男生的人数。0<K<=1000
1<=N 和M<=500.接下来的K行,每行有两个数,分别表示女生Ai愿意和男生Bj做partner。最后一个0结束输入。
 
Output
对于每组数据,输出一个整数,表示可以坐上过山车的最多组合数。
 
Sample Input
6 3 3
1 1
1 2
1 3
2 1
2 3
3 1
0
 
Sample Output
3
 
DFS算法
 #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 (二分图匹配裸题)的更多相关文章

  1. (二分匹配 模板)过山车 -- hdu --2063

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=2063 http://acm.hust.edu.cn/vjudge/contest/view.action ...

  2. hdu 2063 二分图匹配

    题意:一些女的和一些男的有好感,有好感的能一起坐过山车,问最多能组成多少对 hdu 11 页上少有的算法题,二分图匹配问题,匈牙利算法,对于每一个汉子,看和他有好感的妹子有没有配对了,没有配对过就可以 ...

  3. HDU 2063 过山车(模板—— 二分图最大匹配问题)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2063  解题思路: 二分图最大匹配模板题. AC代码: #include<stdio.h> ...

  4. hdu 1281 二分图匹配

    题目:在保证尽量多的“车”的前提下,棋盘里有些格子是可以避开的,也就是说,不在这些格子上放车,也可以保证尽量多的“车”被放下.但是某些格子若不放子,就 无法保证放尽量多的“车”,这样的格子被称做重要点 ...

  5. hdu 4185 二分图匹配

    题意用1*2的木板覆盖矩阵中的‘#’,(木板要覆盖的只能是‘#’),问最多能用几个木板覆盖 将#抽象为二分图的点,一个木板就是一个匹配,注意最后结果要除以2 Sample Input 1 6 .... ...

  6. hdu 1507(二分图匹配)

    Uncle Tom's Inherited Land* Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (J ...

  7. 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 ...

  8. HDU——2444The Accomodation of Students(BFS判二分图+最大匹配裸题)

    The Accomodation of Students Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K ( ...

  9. Fire Net HDU - 1045 (二分图匹配)

    题意: 给出一张图,图中'X'表示wall,'.'表示空地,可以放置blockhouse同一条直线上只能有一个blockhouse,除非有wall 隔开,问在给出的图中最多能放置多少个blockhou ...

随机推荐

  1. Eclipse部署Web项目,常用操作和常见错误的解决方案

    部署Web项目到tomcat 在eclipse中找到Servers项,打开服务器(F3)(建议直接删除服务器,重新建立再设置比较好)1.Servers Locations 中选择Use Tomcat ...

  2. Python基础 条件判断和循环

    pyhton if 语句 if 语句后接表达式,然后用: 表示代码块. age = 20 if age >= 18: print 'your age is', age print 'adult' ...

  3. TCP中的三次握手和四次挥手

    三次握手:目的是同步连接双方的序列号和确认号 并交换 TCP窗口大小信息. 理论上跟通话一样: a: 你听的到吗?  b: 我能听到.只需要两次就可以了,但建立连接阶段不是双向即时通信的,且最终的目的 ...

  4. WebGl 旋转(矩阵变换)

    代码1: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF- ...

  5. HTML标签速记整理W3C

    标题 <h1>段落<p>链接< href="">图像<img src="">自关闭元素,不需要结束标记换行标志& ...

  6. C# 操作word 模板 值 替换

    1.引用 aspose.words   dll 2.word 使用doc 3.给word 模板中添加要替换位置的 书签 .引用 aspose.words dll .word 使用doc .给word ...

  7. 大数据学习--day14(String--StringBuffer--StringBuilder 源码分析、性能比较)

    String--StringBuffer--StringBuilder 源码分析.性能比较 站在优秀博客的肩上看问题:https://www.cnblogs.com/dolphin0520/p/377 ...

  8. python多进程详解和协程

    1.由于python多线程适合于多IO操作,但不适合于cpu计算型工作,这时候可以通过多进程实现.python多进程简单实用 # 多进程,可以cpu保持一致,python多线程适合多io.对于高cpu ...

  9. Reflow & Repaint

    http://www.phpied.com/rendering-repaint-reflowrelayout-restyle/ http://segmentfault.com/a/1190000002 ...

  10. Hystrix使用

    Hystrix是Netflix开源的一款容错系统,能帮助使用者码出具备强大的容错能力和鲁棒性的程序.如果某程序或class要使用Hystrix,只需简单继承HystrixCommand/Hystrix ...