过山车 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 ...
随机推荐
- MAC升级openssl
Mac OSX EI Capitan 10.11.6升级自带Openssl - 简书 Mac10.11升级安装openssl _ 刘春桂的博客 openssl_openssl_ TLS_SSL and ...
- 洛谷P1501 [国家集训队]Tree II(LCT)
题目描述 一棵n个点的树,每个点的初始权值为1.对于这棵树有q个操作,每个操作为以下四种操作之一: + u v c:将u到v的路径上的点的权值都加上自然数c: - u1 v1 u2 v2:将树中原有的 ...
- ionic 环境搭建
1.安装nodejs (8.4.0) 下载地址 https://nodejs.org/zh-cn/ 2.Java jdk 版本号 jdk1.8.0_121 3.安装 cordova npm ins ...
- 100-Days-Of-ML-Code 评注版(Day 2)
Day2_Simple_Linear_Regression(一元线性回归) 本文引用自 Simple Linear Regression, 对其中内容进行了评注与补充说明. 回归分析是一种预测性的建模 ...
- ARM设备树
学习目标:学习设备树相关内容: 一.概念 在Linux 2.6中,ARM架构的板极硬件细节过多地被硬编码在arch/arm/plat-xxx和arch/arm/mach-xxx,在kernel中存在大 ...
- 适合初学Altium Designer的教学视频
以下推荐的我都亲自看过,个人感觉确实不错,可以有助于了解流程,以及一些设计规范 首先是凡亿的PCB教学,贵是贵了点,不过也有免费的,讲解的很详细,而且还有专门的群,610359270 http://w ...
- 前端框架---jQuery---一分钟下载使用
这里通过自己手动的方式“做”一个jQuery来使用,需要5步 1. 访问 https://jquery.com 2. 点击download 3. 拉到最下方,点击 JQuery CDN 4. 得到所有 ...
- 20155239 2016-2017-2 《Java程序设计》第9周学习总
教材学习内容 JDBC 简单功能 连接数据源,如数据库 传给数据库查询和更新指令 获取并处理数据库返回结果(对查询等的响应) public void connectDBAndQuery(String ...
- 20155306 实验三 敏捷开发与XP实践
20155306 实验三 敏捷开发与XP实践 实验内容 XP基础 XP核心实践 相关工具 实验要求 1.没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim编辑器 ...
- 【BZOJ3144】[HNOI2013]切糕
[BZOJ3144][HNOI2013]切糕 题面 题目描述 经过千辛万苦小 A 得到了一块切糕,切糕的形状是长方体,小 A 打算拦腰将切糕切成两半分给小 B.出于美观考虑,小 A 希望切面能尽量光滑 ...