POJ 3189 Steady Cow Assignment 【二分】+【多重匹配】
<题目链接>
题目大意:
有n头牛,m个牛棚,每个牛棚都有一定的容量(就是最多能装多少只牛),然后每只牛对每个牛棚的喜好度不同(就是所有牛圈在每个牛心中都有一个排名),然后要求所有的牛都进牛棚,牛棚在牛心中的排名差计算方法为:所有牛中最大排名和最小排名之差+1(包括区间端点)。问最小的排名差。
解题分析:
先进行二分答案,二分枚举该区间等级的差值,然后根据枚举的区间差值找到所有的等级区间,判断这些等级区间中是否存在符合条件的。判断的依据就是个根据枚举的等级区间,对所有的牛和牛棚进行多重匹配,如果所有的牛都能够分配到牛棚中,则当前枚举的区间符合条件。
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; const int N = 1e3+;
struct Node{
int k,a[N]; //k代表牛棚当前的人数,a[N]存储牛棚中的所有人
}match[N];
int n,B,vis[N];
int G[N][N],capacity[N];
bool dfs(int u,int l,int r){
for(int i=;i<=B;i++){
if(!vis[i]&&G[u][i]>=l&&G[u][i]<=r){ //判断第i个牛棚在牛u心中的等级是否处于枚举的等级中
vis[i]=;
if(match[i].k<capacity[i]){ //如果该牛棚未满,则将牛u(暂时)分配到牛棚i中
match[i].a[++match[i].k]=u;
return true;
}
for(int j=;j<=match[i].k;j++){
if(dfs(match[i].a[j],l,r)){ //如果该牛棚已满,就枚举该牛棚中所有的牛,看他们是否能够找到其他能够分配的牛棚
match[i].a[j]=u; //如果能够找到的话,就用牛u来替代该牛的位置
return true;
}
}
}
}
return false;
}
bool Hungary(int l,int r){
memset(match,,sizeof(match));
for(int i=;i<=n;i++){
memset(vis,,sizeof(vis));
if(!dfs(i,l,r))return false; //只要有一只牛在当前枚举的区间内不能分配到牛棚中,就说明当前枚举的区间不合法
}
return true;
}
int main(){
while(scanf("%d%d",&n,&B)!=EOF){
memset(G,,sizeof(G));
for(int i=;i<=n;i++)
for(int j=;j<=B;j++){
int x;scanf("%d",&x);
G[i][x]=j; //第i头牛,对x牛棚的喜欢度是第j个等级
}
for(int i=;i<=B;i++)
scanf("%d",&capacity[i]); //每个牛棚的容量
int l=,r=B,ans=B;
while(l<=r){
int mid=(l+r)>>; //枚举区间最大等级与最小等级的差值
bool fp=false;
for(int i=;i<=B;i++){ //枚举区间的左端点,即该区间的最小等级
if(Hungary(i,i+mid)){ //判断在该等级范围内,是否满足条件
fp=true;break;
}
}
if(fp)ans=mid+,r=mid-; //ans记录的是该区间的大小,所以需要+1
else l=mid+;
}
printf("%d\n",ans);
}
}
2018-11-17
POJ 3189 Steady Cow Assignment 【二分】+【多重匹配】的更多相关文章
- POJ 3189——Steady Cow Assignment——————【多重匹配、二分枚举区间长度】
Steady Cow Assignment Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I ...
- Poj 3189 Steady Cow Assignment (多重匹配)
题目链接: Poj 3189 Steady Cow Assignment 题目描述: 有n头奶牛,m个棚,每个奶牛对每个棚都有一个喜爱程度.当然啦,棚子也是有脾气的,并不是奶牛想住进来就住进来,超出棚 ...
- POJ3189 Steady Cow Assignment —— 二分图多重匹配/最大流 + 二分
题目链接:https://vjudge.net/problem/POJ-3189 Steady Cow Assignment Time Limit: 1000MS Memory Limit: 65 ...
- POJ 3189 Steady Cow Assignment
题意:每个奶牛对所有的牛棚有个排名(根据喜欢程度排的),每个牛棚能够入住的牛的数量有个上限,重新给牛分配牛棚,使牛棚在牛心中的排名差(所有牛中最大排名和最小排名之差)最小. 题目输入: 首先是两个 ...
- POJ 3189 Steady Cow Assignment【网络流】
题意:每个奶牛对所有的牛棚有个排名(根据喜欢程度排的),每个牛棚能够入住的牛的数量有个上限,重新给牛分配牛棚,使牛棚在牛心中的排名差(所有牛中最大排名和最小排名之差)最小. 牛棚个数最多为20,那么直 ...
- POJ3189_Steady Cow Assignment(二分图多重匹配/网络流+二分构图)
解题报告 http://blog.csdn.net/juncoder/article/details/38340447 题目传送门 题意: B个猪圈,N头猪.每头猪对每一个猪圈有一个惬意值.要求安排这 ...
- Steady Cow Assignment---poj3189(多重匹配+二分)
题目链接:http://poj.org/problem?id=3189 题意:有n头牛,B个牛棚,每头牛对牛棚都有一个喜欢度,接下来输入N*B的矩阵第i行第j列的数x表示:第i头牛第j喜欢的是x; 第 ...
- POJ3189:Steady Cow Assignment(二分+二分图多重匹配)
Steady Cow Assignment Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7482 Accepted: ...
- POJ3189 Steady Cow Assignment
Steady Cow Assignment Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6817 Accepted: ...
随机推荐
- Modbus库开发笔记之七:Modbus其他辅助功能开发
前面开发了各种应用,但是却一直没有提到一个问题,你就是对具体的数据进行读写操作.对于Modbus来说标准的数据有4种:线圈数据(地址:0000x).输入状态量数据(地址:1000x).保持寄存器数据( ...
- JdbcUtil
package com.todaytech.pwp.core.exception; public class BizException extends RuntimeException { publi ...
- Android adb from work ---one
Write in front,You need to know some information first fastboot -help or adb -help (You can view the ...
- bzoj 1856
做这题之前先看道高考真题(好像是真题,我记不清了) 例:已知一个由n个0和n个1排列而成的数列,要求对于任意k∈N*且k∈[1,2n],在前k个数中1的个数不少于0的个数,求当n=4时这样的数列的数量 ...
- vue 的router的简易运用
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- JavaScript实现的抛物线运动效果
css88 技术文档地址: http://www.css88.com/archives/5355 张鑫旭 技术文档地址: https://www.zhangxinxu.com 使用示例: 使用时直接引 ...
- MySQL架构及SQL语句
MySQL基础: 单进程多线程: 用户连接:连接线程 官方组件架构: MySQL的数据文件类型: 数据文件.索引文件 重做日志.撤销日志.二进制日志.错误日志.查询日志.慢查询日志.中继日志 MySQ ...
- jquery 笔记 点击周围区域子类隐藏,点击子类内部的信息 不隐藏
zilei.click(ev){ var e = ev||event; e.stopPropagation(); //dosomething } $(document).click(function( ...
- 论文阅读笔记三十九:Accurate Single Stage Detector Using Recurrent Rolling Convolution(RRC CVPR2017)
论文源址:https://arxiv.org/abs/1704.05776 开源代码:https://github.com/xiaohaoChen/rrc_detection 摘要 大多数目标检测及定 ...
- BZoj 2301 Problem b(容斥定理+莫比乌斯反演)
2301: [HAOI2011]Problem b Time Limit: 50 Sec Memory Limit: 256 MB Submit: 7732 Solved: 3750 [Submi ...