考虑依次选择每一位考生,设当前选到第$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 }

最新文章

  1. SASS教程sass超详细教程
  2. php访问远程服务器上的文件
  3. PAT - 测试 01-复杂度2 Maximum Subsequence Sum (25分)
  4. 【Swift学习】Swift编程之旅(三)
  5. 【COGS 254】【POI 2001】交通网络图
  6. Android开发总是难以入门
  7. CSS透明度大汇总
  8. 3905 - Meteor
  9. VMware Workstation 12 Pro 之安装林耐斯优麒麟 X64系统
  10. Sql Server——查询(一)
  11. day19
  12. Axure文本框验证和外部url的调用
  13. Autel MaxiTPMS TS601 Wireless TPMS Sensor Reset Relearn Activate Programming Tool
  14. ES6语法篇(其一)
  15. Codeforces483B. Friends and Presents(二分+容斥原理)
  16. 使用k8s &amp;&amp; minio 进行 postgres 数据库自动备份
  17. pycharm如何回到过去某个时间
  18. align=&quot;absmiddle&quot; 的意义
  19. Elasticsearch环境准备(一)
  20. C++虚函数解析(转载)

热门文章

  1. bzoj1834 ZJOI2010网络扩容(费用流)
  2. C#开发BIMFACE系列47 IIS部署并加载离线数据包
  3. 命名空间、作用域、LEGB法则、垃圾回收机制
  4. python的参数传递是值传递还是引用传递??
  5. 自动化键盘,python
  6. Java:锁笔记
  7. [no code][scrum meeting] Alpha 10
  8. Noip模拟69 2021.10.5
  9. 编译qwt遇到的问题
  10. Windows平台编译器相关的几个预定义宏