[ACM] HDU 2063 过山车 (二分图,匈牙利算法)

来源:互联网 发布:起个网络名字大全女孩 编辑:程序博客网 时间:2024/05/21 19:28

过山车

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 11509    Accepted Submission(s): 5066


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 31 11 21 32 12 33 10
 


 

Sample Output
3
 


 

Author
PrincessSnow
 


 

Source
RPG专场练习赛

 

解题思路:

感觉匈牙利算法和最大流的算法相似,每次都去找增广路,来获取更多的“回报”。

这篇博文中写的很有意思 http://blog.csdn.net/dark_scope/article/details/8880547 很容易理解匈牙利算法.

代码:

#include <iostream>#include <stdio.h>#include <algorithm>#include <string.h>using namespace std;const int maxn=502;int k,m,n;int g[maxn][maxn];//邻接矩阵来存储边int linked[maxn];//右边的点和左边的哪个点匹配bool vis[maxn];bool dfs(int u){    for(int v=1;v<=n;v++)    {        if(g[u][v]&&!vis[v])        {            vis[v]=1;            if(!linked[v]||dfs(linked[v]))//男生v还没有被匹配或者前面的女生可以选择其他的男生从而该女生u可以匹配男生v            {                linked[v]=u;                return true;            }        }    }    return false;}int hungary(){    int ans=0;    memset(linked,0,sizeof(linked));    for(int u=1;u<=m;u++)    {        memset(vis,0,sizeof(vis));        if(dfs(u))            ans++;    }    return ans;}int main(){    while(scanf("%d",&k)!=EOF&&k)    {        scanf("%d%d",&m,&n);        memset(g,0,sizeof(g));        int l,r;        for(int i=1;i<=k;i++)        {            scanf("%d%d",&l,&r);            g[l][r]=1;        }        printf("%d\n",hungary());    }    return 0;}


 

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 老是想在娘家不想回婆家怎么办 娘家和婆家同时向我借钱怎么办 土地确权后娘家婆家都没有怎么办 结了婚婆家向娘家借钱怎么办? 婆婆的娘家人从我家住怎么办 八个月宝宝断奶后不吃奶粉怎么办 吃母乳的宝宝不吸奶嘴怎么办 宝宝吸了奶嘴不吸母乳怎么办 婴儿吃了奶嘴不吸母乳怎么办 十一个月宝宝断奶不喝奶粉怎么办 孩子三门成绩全不及格家长该怎么办 宝宝快十个月了还不会爬怎么办 小孩写字老把手向里扭曲怎么办 孩子该上四年级了数学差的很怎么办 孩子上三年级了数学成绩好差怎么办 三年级数学老考70-80分怎么办 叛逆期的孩子用死来威胁家长怎么办 叛逆期的孩子抽烟喝酒家长该怎么办 大学遇到不好的老师加课怎么办 两岁的宝宝脾气古怪不听话怎么办 16个月宝宝不听话脾气大怎么办 如果你很害怕去面对一件事怎么办 孩子上幼儿园哭老师不理孩子怎么办 发现幼儿园给孩子吃药片该怎么办 做老师的打学生被家长投诉怎么办 学生认为老师向家长打报告怎么办 老师发打12分的试卷给家长怎么办 孩子在学校顶撞老师不让上学怎么办 被老师骂了不敢去学校怎么办 孩子不爱去幼儿园 总是哭怎么办呢 孩子在幼儿园被老师罚家长该怎么办 孩子不喜欢幼儿园里的体能课怎么办 初中叛逆期的孩子怎么办老师做法 二年级孩子不受老师待见怎么办 孩子该上初中了没学籍怎么办 四个多月的婴儿不喜欢看人怎么办 2个月婴儿不喜欢吃奶粉怎么办 想学习但是又学不进去怎么办 在省外读书 回来读高中学籍怎么办 一岁宝宝这几天不爱吃饭怎么办 2岁的宝宝吃多了怎么办