题目链接

(BZOJ) 大人,时代变了
(Gym) https://codeforces.com/gym/101190
(Luogu) https://www.luogu.com.cn/problem/P6967
(LOJ) https://loj.ac/p/6079

题解

想了一晚上,终于有点理解了,好神仙啊。
我只会纯网络流的做法,并不会线性规划。

首先题意显然是有一个序列每个位置可以选 \(0\) 或 \(1\),收益分别是 \(a_i\) 和 \(b_i\),且满足每个长度为 \(m\) 的区间里选 \(1\) 的个数在 \([L,R]\) 内。
区间个数的限制似乎在网络流中难以体现,于是有一种思路是把区间和点进行转化。也就是我们有 \((n-m+1)\) 种区间,不妨设按照左端点编号,那么对于每个点,如果选了 \(1\) 会给编号在一个区间内的区间的选 \(1\) 个数增加 \(1\)(或者选 \(0\) 的个数减少 \(1\))。这个在网络流中的体现是用一条边从 \(i\) 指向 \((i+m)\),分走 \(1\) 的流量,后面再还回来。
那么就有了一个上下界费用流的建图:建立源点 \(S\) 和 \(0,1,2,...,n-m+1\),连边 \((S,0,[0,m],0),(i,i+1,[n-R,n-L],0),(\max(0,i-m),\min(n-m+1,i),[0,1],b_i-a_i)\),然后求 \(S\) 到 \((n-m+1)\) 的最大费用最大流,答案再加上 \(\sum^n_{i=1}a_i\). 一单位的流量流过 \((i,i+1)\) 代表选了 \(0\),否则代表选了 \(1\).
但这样似乎并不优美。考虑优化成不带上下界的费用流。
我们其实没有必要拘泥于让 \((i,i+1)\) 流过一单位流量代表选了 \(0\). 我们只要把 \(1\) 的选出来就好了!我们从源点往 \(0\) 连流量为 \(R\) 的边,代表任何时刻不可能分走超过 \(R\) 的流量。然后再将 \((i,i+1)\) 的边流量设置为 \(R-L\),意味着至少有 \(L\) 的流量要被分走。
于是做完了,时间复杂度 \(O(MFMC(n,2n))\).

代码

太久没写网络流了,甚至拉完板子后忘记了边数要初始化成 \(1\)……

#include<bits/stdc++.h>
#define llong long long
#define mkpr make_pair
#define x first
#define y second
#define iter iterator
#define riter reverse_iterator
#define y1 Lorem_ipsum_
#define tm dolor_sit_amet_
using namespace std;inline int read()
{int x = 0,f = 1; char ch = getchar();for(;!isdigit(ch);ch=getchar()) {if(ch=='-') f = -1;}for(; isdigit(ch);ch=getchar()) {x = x*10+ch-48;}return x*f;
}namespace NetFlow
{const int N = 1002;const int M = 2002;const llong INF = 1e13;struct Edge{int u,v,nxt,w; llong c;} e[(M<<1)+3];int fe[N+3];llong dis[N+3];int que[N+5];bool inq[N+3];int lst[N+3];int n,m,en,s,t; llong mf,mc;void addedge(int u,int v,int w,llong c){en++; e[en].u = u,e[en].v = v,e[en].w = w,e[en].c = c;e[en].nxt = fe[u]; fe[u] = en;en++; e[en].u = v,e[en].v = u,e[en].w = 0,e[en].c = -c;e[en].nxt = fe[v]; fe[v] = en;}bool spfa(){for(int i=1; i<=n; i++) dis[i] = -INF;int hd = 1,tl = 2; que[1] = s; dis[s] = 0; inq[s] = true;while(hd!=tl){int u = que[hd]; hd++; if(hd>n+1) hd-=n+1;for(int i=fe[u]; i; i=e[i].nxt){int v = e[i].v;if(e[i].w>0&&dis[e[i].v]<dis[u]+e[i].c){dis[e[i].v] = dis[u]+e[i].c; lst[e[i].v] = i;if(!inq[e[i].v]){inq[e[i].v] = true;que[tl] = e[i].v; tl++; if(tl>n+1) tl-=n+1;}}}inq[u] = false;}return dis[t]!=-INF;}void calcflow(){int flow = 1e5;for(int u=t; u!=s; u=e[lst[u]].u){flow = min(flow,e[lst[u]].w);}for(int u=t; u!=s; u=e[lst[u]].u){e[lst[u]].w -= flow; e[lst[u]^1].w += flow;}mf += flow; mc += 1ll*flow*dis[t];}llong mfmc(int _n,int _s,int _t){n = _n,s = _s,t = _t; mf = 0,mc = 0ll;while(spfa()) {calcflow();} return mc;}
}
using NetFlow::addedge;
using NetFlow::mfmc;const int mxN = 1000;
int n,m,al,ar;
llong a[mxN+3],b[mxN+3];int main()
{n = read(),m = read(),ar = m-read(),al = read(); NetFlow::en = 1;for(int i=1; i<=n; i++) a[i] = read(); for(int i=1; i<=n; i++) b[i] = read();llong ans = 0ll;for(int i=1; i<=n; i++) ans += a[i];addedge(1,2,ar,0);for(int i=1; i<=n; i++){addedge(max(0,i-m)+2,min(n-m+1,i)+2,1,b[i]-a[i]);}for(int i=0; i<n-m+1; i++){addedge(i+2,i+1+2,ar-al,0);}ans += mfmc(n-m+3,1,n-m+1+2);printf("%lld\n",ans);for(int i=1; i<=n; i++){if(NetFlow::e[2*i+2].w==0) {printf("E");} else {printf("S");}}puts("");return 0;
}

Gym 101190D BZOJ 4842 Luogu P6967 LOJ #6071 [NEERC2016]Delight for a Cat (费用流)相关推荐

  1. BZOJ.4842.[NEERC2016]Delight for a Cat(费用流)

    BZOJ 参考这儿. 首先如果一个活动的时间满足条件,那么另一个活动也一定满足.还有就是这题就是费用流没有为什么.不妨假设最初所有时间都用来睡觉,那么我们要对每个\(k\)大小区间选出\([t2,k- ...

  2. BZOJ 1920 Luogu P4217 [CTSC2010]产品销售 (模拟费用流、线段树)

    题目链接 (bzoj) https://www.lydsy.com/JudgeOnline/problem.php?id=1920 (luogu) https://www.luogu.org/prob ...

  3. BZOJ 1834 Luogu P2604 [ZJOI2010]网络扩容 (最小费用最大流)

    题目连接: (luogu) https://www.luogu.org/problemnew/show/P2604 (bzoj) https://www.lydsy.com/JudgeOnline/p ...

  4. UOJ #219 BZOJ 4650 luogu P1117 [NOI2016]优秀的拆分 (后缀数组、ST表)

    UOJ #219 BZOJ 4650 luogu P1117 [NOI2016]优秀的拆分 (后缀数组.ST表) 连NOI Day1T1都不会做...看了题解都写不出来还要抄Claris的代码.. 题 ...

  5. UOJ #131 BZOJ 4199 luogu P2178【NOI2015】品酒大会 (后缀自动机、树形DP)

    UOJ #131 BZOJ 4199 luogu P2178[NOI2015]品酒大会 (后缀自动机.树形DP) 水是水,但是写出了不少问题,因此写一发博客. https://www.luogu.or ...

  6. BZOJ 1500 Luogu P2042 [NOI2005] 维护数列 (Splay)

    BZOJ 1500 Luogu P2042 [NOI2005] 维护数列 (Splay) 手动博客搬家: 本文发表于20180825 00:34:49, 原地址https://blog.csdn.ne ...

  7. BZOJ 3930 Luogu P3172 选数 (莫比乌斯反演)

    BZOJ 3930 Luogu P3172 选数 (莫比乌斯反演) 手动博客搬家:本文发表于20180310 11:46:11, 原地址https://blog.csdn.net/suncongbo/ ...

  8. POJ 1061 BZOJ 1477 Luogu P1516 青蛙的约会 (扩展欧几里得算法)

    POJ 1061 BZOJ 1477 Luogu P1516 青蛙的约会 (扩展欧几里得算法) 手动博客搬家: 本文发表于20180226 23:35:26, 原地址https://blog.csdn ...

  9. BZOJ 1101 Luogu P3455 POI 2007 Zap (莫比乌斯反演+数论分块)

    BZOJ 1101 Luogu P3455 POI 2007 Zap (莫比乌斯反演+数论分块) 手动博客搬家: 本文发表于20171216 13:34:20, 原地址https://blog.csd ...

最新文章

  1. hihocoder offer收割编程练习赛11 B 物品价值
  2. 白话SpringCloud | 第八章:分布式配置中心的服务化及动态刷新
  3. android 之自定义Adapter的用法
  4. 【原创】我所理解的自动更新-外网web服务器配置
  5. navicat修改表的主键自增长报错
  6. ARM处理器基本指令大全
  7. Mysql启动报错:本地计算机上的mysql服务启动停止后,某些服务在未由其他服务或程序使用时将自动停止
  8. java if if else语句_Java if else条件判断语句用法
  9. VIM 第五节:文件信息、跳转、定位括号和缩进 https://fishc.com.cn/thread-65856-1-1.html
  10. 计算机论文格式要求吗,计算机论文格式(写作要求详细介绍)
  11. Linux显卡fps性能测试,如何检测应用帧率-FPS测试
  12. Nginx不解析PHP,无法打开PHP文件
  13. Postman 接口测试神器
  14. 金仓数据库 KingbaseES插件参考手册 F
  15. 前度字符串转数组_leetcode每日一题
  16. 唯品会的html文件,唯品会网页打不开
  17. golang: 密码中允许出现数字、大写字母、小写字母、特殊字符,但至少包含其中2种且长度在8-16之间(四种符号任意满足三种即可)
  18. 超微A+ Server 4124GS-TNR做主板集成RAID
  19. 医用计算机应用,医用计算机应用基础与实训教程
  20. Fiddler简单的使用教程(入门级)

热门文章

  1. 关于考研一些问题的思考2017-12-23
  2. 安顺计算机二级考试,安顺市2020年3月计算机二级报名时间|网上报名入口【12月18日9:00开通】...
  3. java switch 值_Java switch多值匹配操作详解
  4. sqlserver存储过程的参数传递注意事项
  5. FFmpeg中实现对多媒体信息的获取与打印av_dump_format
  6. 拔掉 MacBookPro,用 8GB 树莓派4 工作一天,体验原来是这样的
  7. STM32-中断优先级
  8. BugkuCTF-Misc:细心的大象
  9. SQL语句快速回忆——SQL基础知识点汇总
  10. 四个标志位SF,ZF,OF,CF