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. Java中 方法的多态 简析图

    代码如下: public class Client{    public static void main(String[] args){        Person p = new Person() ...

  2. jQuery的$.get()函数不执行以及php端报错Uncaught Error: Call to a member function bind_param() on boolean in...

    写了一个html,用到了jQuery,发现没有按照预期的结果显示,最后定位到是$.get()函数没有运行 调试过程为: 在页面右击查看元素,到网络那一栏,找到类型为json的那个包点击,然后查看响应, ...

  3. echarts使用方法

    1.引入完整版echarts.min.js. 2.为ECharts准备一个具备大小(宽高)的Dom . <div id="main" style="width: 6 ...

  4. 解决ios下audio不能正常播放的问题

    解决ios下audio不能正常播放的问题 ios系统下会自动屏蔽audio标签的自动播放,需要使用一个事件来驱动音频播放 this.$refs.startaudio.addEventListener( ...

  5. 购物车业务逻辑(vuex)

    list(列表页): 1:发送ajax请求,获取相应的数据 2:给每一个上平添加一个点击事件 3:每一个商品都要有一个ID 4:当点击商品时,将商品id值传递给详情页 details(详情页): 1: ...

  6. Go语言反射之值反射

    1 概述 反射不仅可以获取值的类型信息,还可操作变量的值.使用 reflect.Value 类型操作变量的值. 2 值反射对象 reflect.ValueOf() 方法可以获取一个值的反射对象,之后可 ...

  7. # 第五周课下测试(ch03)补交

    第五周课下测试(ch03)补交 1.( 多选题 | 1 分) 有关gdb调试汇编,下面说法正确的是() A . 可以用disas反汇编当前函数 B . 以16进制形式打印%rax中内容的命令是 pri ...

  8. 20155211 2016-2017-2 《Java程序设计》第2周学习总结

    20155211 2016-2017-2 <Java程序设计>第2周学习总结 教材学习内容总结 通过对教材的阅读,我理解到Java中对于整数,浮点数等类型的定义与c语言基本相同. 对字面常 ...

  9. 20155213 实验一《Java开发环境的熟悉》实验报告

    20155213 实验一<Java开发环境的熟悉>实验报告 一. 实验内容及步骤 (一)使用JDK编译.运行简单的java程序 命令行下的程序开发 输入cd Code进入Code文件夹里 ...

  10. C语言复习20170826

    数组 先定义,再初始化,最后使用. 访问数组中的元素可以采用数组名加下标的方式,下标是从0开始,c并不检查数组下标是否越界,所以在访问数组中的元素时需要注意,需要对数组下标做判断,防止访问数组越界. ...