考虑依次选择每一位考生,设当前选到第$i+1$位,前i个分别为$p1,p2,……pi$(注意:这里只确定了导师的志愿编号),然后枚举第$p_{i+1}$,通过网络流建图+判定,复杂度为$o(nm*f(n+m,cn))$($f(n,m)$表示点数为n、边数为m的网络流),无法通过
考虑优化,由于网络流可以先任意流,那么直接在之前的残余网络上加上第k份志愿并判断能否联通即可,复杂度$o(cn^{2}m)$
第二个问题类似,存储下每一次跑完后的残余网络,然后从下往上枚举其排名(志愿为si及其以上的)并建图,复杂度同样为$o(cn^{2}m)$

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 205
4 struct ji{
5 int nex,to,len;
6 }edge[30*N],e[N][30*N];
7 vector<int>v[N][N];
8 int E,t,n,m,x,EE[N],head[N<<1],vis[N<<1],h[N][N<<1];
9 void add(int x,int y,int z){
10 edge[E].nex=head[x];
11 edge[E].to=y;
12 edge[E].len=z;
13 head[x]=E++;
14 }
15 bool dfs(int k){
16 if (k==n+m+1)return 1;
17 if (vis[k])return 0;
18 vis[k]=1;
19 for(int i=head[k];i!=-1;i=edge[i].nex)
20 if ((edge[i].len)&&(dfs(edge[i].to))){
21 edge[i].len--;
22 edge[i^1].len++;
23 return 1;
24 }
25 return 0;
26 }
27 int main(){
28 scanf("%d%*d",&t);
29 while (t--){
30 scanf("%d%d",&n,&m);
31 E=0;
32 memset(head,-1,sizeof(head));
33 for(int i=1;i<=n;i++)
34 for(int j=1;j<=m;j++)v[i][j].clear();
35 for(int i=1;i<=m;i++){
36 scanf("%d",&x);
37 add(i+n,n+m+1,x);
38 add(n+m+1,i+n,0);
39 }
40 for(int i=1;i<=n;i++)
41 for(int j=1;j<=m;j++){
42 scanf("%d",&x);
43 if (x)v[i][x].push_back(j);
44 }
45 EE[0]=E;
46 memcpy(h[0],head,sizeof(head));
47 memcpy(e[0],edge,sizeof(edge));
48 for(int i=1;i<=n;i++){
49 bool flag=0;
50 EE[i]=E;
51 memcpy(h[i],head,sizeof(head));
52 memcpy(e[i],edge,sizeof(edge));
53 for(int j=1;j<=m;j++){
54 E=EE[i];
55 memset(vis,0,sizeof(vis));
56 memcpy(head,h[i],sizeof(head));
57 memcpy(edge,e[i],sizeof(edge));
58 for(int k=0;k<v[i][j].size();k++){
59 add(i,v[i][j][k]+n,1);
60 add(v[i][j][k]+n,i,0);
61 }
62 if (dfs(i)){
63 flag=1;
64 printf("%d ",j);
65 break;
66 }
67 }
68 if (!flag)printf("%d ",m+1);
69 EE[i]=E;
70 memcpy(h[i],head,sizeof(head));
71 memcpy(e[i],edge,sizeof(edge));
72 }
73 printf("\n");
74 for(int i=1;i<=n;i++){
75 scanf("%d",&x);
76 bool flag=0;
77 for(int j=i;j;j--){
78 E=EE[j-1];
79 memset(vis,0,sizeof(vis));
80 memcpy(head,h[j-1],sizeof(head));
81 memcpy(edge,e[j-1],sizeof(edge));
82 for(int k=1;k<=x;k++)
83 for(int l=0;l<v[i][k].size();l++){
84 add(i,v[i][k][l]+n,1);
85 add(v[i][k][l]+n,i,0);
86 }
87 if (dfs(i)){
88 flag=1;
89 printf("%d ",i-j);
90 break;
91 }
92 }
93 if (!flag)printf("%d ",i);
94 }
95 printf("\n");
96 }
97 }

[loj2477]劈配的更多相关文章

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

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

  2. 【BZOJ5251】【八省联考2018】劈配(网络流,二分答案)

    [BZOJ5251][八省联考2018]劈配(网络流,二分答案) 题面 洛谷 BZOJ Description 一年一度的综艺节目<中国新代码>又开始了. Zayid从小就梦想成为一名程序 ...

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

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

  4. [BZOJ5251][多省联测2018]劈配

    bzoj luogu sol 从前往后依次加边,每次对一个人做完劈配后就把当前这个残余网络存下来.这样第二问就可以二分排在第几名然后check一下在对应排名的残余网络上还能不能再增广. 给网络流开结构 ...

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

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

  6. bzoj 5251: [2018多省省队联测]劈配

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

  7. bzoj5251 [2018多省省队联测]劈配

    直接网络流模拟即可AC. 可持久化+暴力=90分, 可持久化+二分=30分, 暴力加边+二分=100分. 我也很无奈啊. Ivan便涨红了脸,额上的青筋条条绽出,争辩道,“memcpy也是可持久化…… ...

  8. bzoj千题计划321:bzoj5251: [2018多省省队联测]劈配(网络流 + 二分)

    https://www.lydsy.com/JudgeOnline/problem.php?id=5251 第一问: 左边一列点代表学生,右边一列点代表导师 导师向汇点连流量为 人数限制的 边 然后从 ...

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

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

随机推荐

  1. 无法解析的外部符号之_cvLoadImage,_cvCreateMat,_cvReleaseImage之类

    一个错误可能是:附加依赖项少添加了库函数: 还有一个可能是:配置设置错误了,比如该是64位,却设置成win32了.改过来就好了. 要注意opencv的使用中 在Debug.Release模式以及x64 ...

  2. 山顶点提取(ArcPy实现)

    一.背景 山顶点指哪些在特定邻域分析范围内,该点都比周围点高的区域.山顶点是地形的重要特征点,它的分布与密度反映了地貌的发育特征,同时也制约着地貌发育.因此,如何基于DEM数据正确有效的提取山顶点,在 ...

  3. QQ三国 秘制机簧去哪打?打的太慢?

    我在完成这个任务时卡了很久,因为打的效率极低,因此最后我是如何完成的. 1. 先说打谁吧,刚开始我打机簧蜘蛛,就没打出来过,,后来换了机簧车,掉率就上升了,建议打机簧车. 2. 如果你一直打不出来,建 ...

  4. 题解「2017 山东一轮集训 Day1 / SDWC2018 Day1」Set

    题目传送门 题目大意 给出一个长度为 \(n\) 的数组,选出一些数异或之和为 \(s1\),其余数异或之和为 \(s2\),求 \(s1+s2\) 最大时 \(s1\) 的最小值. 思路 你发现如果 ...

  5. AutoCAD云产品平台ForgeViewer格式离线部署思路分析

    背景 在上一篇博文中CAD图DWG解析WebGIS可视化技术分析总结提到,利用AutoCAD的自有云产品 Autodesk Forge,能在浏览器中渲染 3D 和 2D 模型数据,实现DWG图形的We ...

  6. DataX的安装及使用

    DataX的安装及使用 目录 DataX的安装及使用 DataX的安装 DataX的使用 stream2stream 编写配置文件stream2stream.json 执行同步任务 执行结果 mysq ...

  7. 【UE4】基础概念——文件结构、类型、反射、编译、接口、垃圾回收、序列化

    新标签打开或者下载看大图 思维导图 Engine Structure Pipeline Programming Pipeline Blueprint Pipeline

  8. 【UE4 C++】解析与构建 XML 数据,XmlParser 与 tinyxml

    XmlParser 简单读取 XmlParser 为引擎自带模块 XML 文件 <?xml version="1.0" encoding="UTF-8"? ...

  9. LeetCode:数组专题

    数组专题 有关数组的一些 leetcode 题,在此做一些记录,不然没几天就忘光光了 二分查找 双指针 滑动窗口 前缀和/差分数组 二分查找 本文内容摘录自公众号labuladong中有关二分查找的文 ...

  10. springBoot服务整合线程池ThreadPoolTaskExecutor与@Async详解使用

    ThreadPoolExecutor:=======这个是java自己实现的线程池执行类,基本上创建线程池都是通过这个类进行的创建.ThreadPoolTaskExecutor:========这个是 ...