https://www.lydsy.com/JudgeOnline/problem.php?id=5251

https://loj.ac/problem/2477  <-可以看数据

https://www.luogu.org/problemnew/show/P4382

题面太长,请自行读完之后再看本题。

考试的时候让我伤心的一道题,分明想的就是正解结果sb般第二问没二分丢了15分。

如果b=1就是一个显然的匈牙利匹配了。

考虑b!=1也只不过就是让一个导师可以多匹配几个人而已,额外记录这个导师是否还能匹配人即可。

那么对于第一问显而易见匈牙利算法即可完成,复杂度最差就是每个人的其中一个志愿被我们遍历一遍,于是一次匈牙利是O(n*c),总共O(n^2*c)。

第二问二分答案后对这个点再匈牙利一次,实际就是清出答案和现在这个点之间的点的所有答案,而且我们已经知道了它之前的所有人的志愿和导师选择,因此大可以直接复制下来而不用重新跑一遍。

因此是O(n^2*logn*c)轻松跑过。

(至于为什么debug这么久纯粹是因为我傻,没有考虑匈牙利算法可以增广的不只有它前面的点,还可以有后面的点。)

总结:一道好题,洛谷评分虚高,实际为省选/NOI-,但是为了纪念我debug的时间之长,于是评了个NOI。

#include<cmath>
#include<cstdio>
#include<cstring>
#include<vector>
#include<algorithm>
#include<iostream>
using namespace std;
const int N=;
inline int read(){
int X=,w=;char ch=;
while(ch<''||ch>''){if(ch=='-')w=-;ch=getchar();}
while(ch>=''&&ch<='')X=(X<<)+(X<<)+ch-'',ch=getchar();
return X*w;
}
int n,m,b[N],bb[N],s[N];
int ds[N],zy[N],dds[N],zzy[N];
int a[N][N][],len[N][N];
bool vis[N];
bool dfs(int k,int w){
for(int j=;j<=len[k][w];j++){
int u=a[k][w][j];
if(vis[u])continue;
vis[u]=;
if(b[u]){
ds[k]=u;zy[k]=w;
b[u]--;
return ;
}else{
for(int l=;l<=n;l++){//这里debug 3h+才发现。
if(l==k)continue;
if(ds[l]==u){
if(dfs(l,zy[l])){
ds[k]=u;zy[k]=w;
return ;
}
}
}
}
}
return ;
}
inline void copy(int k){
for(int i=;i<=m;i++)b[i]=bb[i];
for(int i=;i<=k;i++){
ds[i]=dds[i];
zy[i]=zzy[i];
b[ds[i]]--;
}
for(int i=k+;i<=n;i++)ds[i]=-;
return;
}
inline void work2(){
for(int i=;i<=n;i++){
if(zzy[i]<=s[i])printf("0 ");
else{
int l=,r=i-,ans=;
while(l<=r){
int mid=(l+r)>>;
bool ok=;
copy(mid-);
memset(vis,,sizeof(vis));
for(int j=;j<=s[i];j++){
if(dfs(i,j)){
ans=mid;l=mid+;
ok=;
break;
}
}
if(!ok)r=mid-;
}
printf("%d ",i-ans);
}
}
puts("");
}
inline void work1(){
for(int i=;i<=n;i++){
memset(vis,,sizeof(vis));
for(int j=;j<=m;j++){
if(!len[i][j])continue;
if(dfs(i,j))break;
}
}
for(int i=;i<=n;i++){
zzy[i]=zy[i];dds[i]=ds[i];
printf("%d ",zy[i]);
}
puts("");
}
inline void init(){
n=read(),m=read();
memset(len,,sizeof(len));
for(int i=;i<=m;i++)bb[i]=b[i]=read();
for(int i=;i<=n;i++){
zy[i]=m+;ds[i]=-;
for(int j=;j<=m;j++){
int k=read();
if(k)a[i][k][++len[i][k]]=j;
}
}
for(int i=;i<=n;i++)s[i]=read();
}
int main(){
int t=read(),c=read();
while(t--){
init();
work1();
work2();
}
return ;
}

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/+

+++++++++++++++++++++++++++++++++++++++++++

BZOJ5251:[九省联考2018]劈配——题解的更多相关文章

  1. [BZOJ5251][九省联考2018]劈配(网络流)

    5251: [2018多省省队联测]劈配 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 33  Solved: 22[Submit][Status][ ...

  2. BZOJ5251 八省联考2018劈配(网络流)

    劈配,匹配,网络流.那么考虑怎么跑网络流. 先看第一问.首先套路的建出超源超汇.不用想也知道导师向汇连容量为战队人数上限的边.特别地,给出局也建一个点,向汇连容量inf的边(似乎没有必要).对于一个新 ...

  3. luogu P4382 [九省联考2018]劈配

    luogu 我记得我第一次做这道题的时候屁都不会qwq 先考虑第一问,暴力是依次枚举每个人,然后从高到低枚举志愿,枚举导师,能选就选.但是可以发现前面的人选的导师可能会导致后面的人本来可以选到这个志愿 ...

  4. [八省联考2018] 劈配 mentor

    Description 一年一度的综艺节目<中国新代码>又开始了.Zayid 从小就梦想成为一名程序员,他觉得这是一个展示自己的舞台,于是他毫不犹豫地报名了. Input 轻车熟路的Zay ...

  5. BZOJ.5251.[八省联考2018]劈配mentor(最大流)

    BZOJ 洛谷 对于每个人,每次枚举一个志愿看是否能增广即可. 对于第二问,可以保留第一问中\(n\)次增广前后的\(n\)张图,二分,在对应图上看是否能增广即可. 貌似匈牙利的某种写法比网络流优多了 ...

  6. 洛谷P4382 [八省联考2018]劈配(网络流,二分答案)

    洛谷题目传送门 说不定比官方sol里的某理论最优算法还优秀一点? 所以\(n,m\)说不定可以出到\(1000\)? 无所谓啦,反正是个得分题.Orz良心出题人,暴力有70分2333 思路分析 正解的 ...

  7. P4382 [八省联考2018]劈配

    题目链接 题意分析 受到了\(olinr\ \ julao\)的影响 写了匈牙利算法 首先 我们对于每一个人 从高到低枚举志愿 如果当前志愿的老师有剩余的话 那么我们就选 否则的话 我们看看谁的那个志 ...

  8. [九省联考2018]秘密袭击coat

    [九省联考2018]秘密袭击coat 研究半天题解啊... 全网几乎唯一的官方做法的题解:链接 别的都是暴力.... 要是n=3333暴力就完了. 一.问题转化 每个联通块第k大的数,直观统计的话,会 ...

  9. 【BZOJ5250】[九省联考2018]秘密袭击(动态规划)

    [BZOJ5250][九省联考2018]秘密袭击(动态规划) 题面 BZOJ 洛谷 给定一棵树,求其所有联通块的权值第\(k\)大的和. 题解 整个\(O(nk(n-k))\)的暴力剪剪枝就给过了.. ...

随机推荐

  1. unable to access android sdk add-on list and SDK 更新镜像设置

    前记 国内的网络呀,真是操蛋!!!!!! unable to access android sdk add-on list 在 Android Studio 安装目录 bin/idea.propert ...

  2. Oracle作业练习题

    第一问 //登陆scott用户 //解锁 alter user scott account unlock; //给用户申请密码 alter user scott identified by tiger ...

  3. java并发总览

  4. 如何在线测试Exchange的速度

    最新碰到了客户需要比较国内版和国际版的Office365的速度问题,微软提供在线工具测试 这里以Exchange 测试为例子,请参考. PS Onenote贴过来只能至图片,各位看官只能将就了 这里有

  5. 从零开始的Python学习Episode 2——运算符与while循环

    一.算术运算符 加法:+,减法:-,乘法*,除法/,整除(地板除)//,取余%,乘方**.  二.逻辑运算符 且:and,或:or,非:not 优先级:not>and>or 短路原则: 对 ...

  6. Python最长连续数列的O(n)解法

    题目 输入一个乱序的连续数列,输出其中最长连续数列长度,要求算法复杂度为 O(n) . 输入样例 100,4,200,1,3,2 54,55,300,12 1 5,4,3,2,1 1,2,3,4,5, ...

  7. 名人问题 算法解析与Python 实现 O(n) 复杂度 (以Leetcode 277. Find the Celebrity为例)

    1. 题目描述 Problem Description Leetcode 277. Find the Celebrity Suppose you are at a party with n peopl ...

  8. Matlab提速方法

    1. 向量化. 尽量少用for循环. 2. 循环竖着走比横着走快. 3. 内置函数也有优化的空间 不少内置函数都有大量的error check.直接用profiler找出真正干活的.不少内置函数在网上 ...

  9. block知识总结

    一.block在内存中存在的形式 1.当把block句法写在函数或者方法外面时,系统会在静态数据区分配一块内存区域给block对象.这片区域在程序执行期会一直存在. 2.当block句法写在函数或者方 ...

  10. SOA架构的理解

    实践论认为:从实践提升到理论,再由理论指导实践,由此向前发展.目前SOA的发展的情况………… 通过不少实践,SOA的模型己经被公认为标准规范,目前是正需要进一步总结上升到理论的时候了. SOA架构的演 ...