CF933E A Preponderant Reunion DP
题解搬运工
设原问题为问题A。每一次减少\(\min\{p_i , p_{i+1}\}\)难以处理,我们考虑将限制变得宽松一些:每一次可以减少\([1,\min\{p_i , p_{i+1}\}]\)的任意值,需要满足的终止条件与问题A相同。我们称其为问题B,设区间\([l,r]\)在问题B操作下的答案为\(g_{l,r}\)。显然问题B的答案要小于等于问题A。
再考虑:在问题AB中,最后的结果一定是两个正数之间有一段0。我们再考虑:设\(f_{l,r}\)表示只操作区间\([l,r]\)使得区间\([l,r]\)的值全部小于等于\(0\)(可以为负)的最小代价,设其为问题C。不难发现:设\(c_l = p_l\),\(c_i = \max\{p_i - c_{i-1} , 0\} , i \in [l+1,r]\),那么\(f_{l,r} = \sum\limits_{i=l}^r c_i\)。
首先,\(f_{l,l} = g_{l-1,l+1}\),\(f_{l,l+1} = g_{l-1,l+2}\),而
\(f_{l,r} = \sum\limits_{i=l}^rc_i = \sum\limits_{i=l}^{r-2}c_i + c_{r-1} + \max\{p_r - c_{r-1} , 0\} = f_{l,r-2} + \max\{p_r , c_{r-1}\} \geq f_{l,r-2} + f_{r,r}\)
不难发现中间漏掉了一个\(r-1\),相当于\(r-1\)不变为\(0\),而\([l,r-2]\)和\([r,r]\)变为\(0\),也就是说在最优情况中\(r-1\)会保留下来,即\(g_{l-1,r+1} = g_{l-1,r-1} + g_{r-1,r+1}\)。不断递归下去就可以知道\(g_{l-1,r+1}\)的最优情况中,极长的\(0\)连续段不会超过\(2\)。
因为极长\(0\)段小于等于\(2\),所以问题C中不会出现负数,所以问题C中构造的解在问题B中一定满足。至此我们完成了C到B的转化。
同时注意到问题B中的所有操作一定会让若干个数变为\(0\),所以在问题B中的可行操作在问题A中也一定可行(这个感性理解好了,不知道怎么严格证明),即在问题A中极长连续\(0\)段长度不会超过\(2\)
接下来考虑DP:设\(f_{i}\)表示以\(i\)结尾、选择\(i\)的\([1,i]\)的最优答案,转移考虑其之前选择多少个\(0\),并记下转移点。值得注意的是如果存在两个\(0\),那么最少步数一定是\(\max\{p_{i-1} , p_{i-2}\}\),即先对\(p_{i-1} , p_{i-2}\)做一次,剩下的一次再做完。最后还原DP结果输出构造方案即可。
值得注意的一点是如果\(f_i\)的操作过程中使得某个数变为负数是一定不优的,由问题C就可以知道这一点。
CF933E A Preponderant Reunion DP的更多相关文章
- 【CF933E】A Preponderant Reunion(动态规划)
[CF933E]A Preponderant Reunion(动态规划) 题面 CF 洛谷 题解 直接做很不好搞,我们把条件放宽,我们每次可以选择两个相邻的非零数让他们减少任意值,甚至可以减成负数(虽 ...
- BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]
1911: [Apio2010]特别行动队 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 4142 Solved: 1964[Submit][Statu ...
- 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...
- AEAI DP V3.7.0 发布,开源综合应用开发平台
1 升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...
- AEAI DP V3.6.0 升级说明,开源综合应用开发平台
AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...
- BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]
1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4026 Solved: 1473[Submit] ...
- [斜率优化DP]【学习笔记】【更新中】
参考资料: 1.元旦集训的课件已经很好了 http://files.cnblogs.com/files/candy99/dp.pdf 2.http://www.cnblogs.com/MashiroS ...
- BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]
1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 9812 Solved: 3978[Submit][St ...
- px、dp和sp,这些单位有什么区别?
DP 这个是最常用但也最难理解的尺寸单位.它与“像素密度”密切相关,所以 首先我们解释一下什么是像素密度.假设有一部手机,屏幕的物理尺寸为1.5英寸x2英寸,屏幕分辨率为240x320,则我们可以计算 ...
随机推荐
- 本地局域网yum源搭建-centos/redhat
环境-centos6.7 [本机yum搭建提前备好,不做介绍] [root@nagios ~]# cat /etc/redhat-release CentOS release 6.7 (Final) ...
- VMware网络适配器
VMware 提供的网络连接有 5 种,分别是"桥接模式"."NAT 模式"."仅主机模式"."自定义"和"L ...
- Spring Cloud Feign 调用过程分析
前面已经学习了两个Spring Cloud 组件: Eureka:实现服务注册功能: Ribbon:提供基于RestTemplate的HTTP客户端并且支持服务负载均衡功能. 通过这两个组件我们暂时可 ...
- 使用CompletableFuture实现业务服务的异步调用实战代码
假如我有一个订单相关的统计接口,需要返回3样数据:今日订单数.今日交易额.总交易额. 一般的我们的做法是串行调用3个函数,把调用返回的结果返回给调用者,这3次调用时串行执行的,如果每个调用耗时1秒的话 ...
- Centos7.6使用yum安装PHP7.2
Centos7.6使用yum安装PHP7.2 1.安装源 安装php72w,是需要配置额外的yum源地址的,否则会报错不能找到相关软件包. php高版本的yum源地址,有两部分,其中一部分是epel- ...
- /bin/sh^M:解释器错误:没有那个文件或目录
在win下编辑的时候,换行结尾是\n\r , 而在linux下 是\n,所以才会有 多出来的\rsed -i 's/\r$//' configure 删除configure脚本中的\r
- vue-cli3项目关闭烦人的代码检测
参考博客:https://blog.csdn.net/e1172090224/article/details/99636767 vue.config.js module.exports = { lin ...
- Python - Django - auth 模块
生成数据库 查看 auth_user 数据库 给 auth_user 表创建一个超级用户 邮箱地址可以不写 再看一下 auth_user 表 密码被加密了 login.html: <!DOCTY ...
- [原]部署kubernetes dashboard(二)
####################### 以下为声明 ##################### 此文档是之前做笔记在两台机上进行的实践,kubernetes处于不断开发阶段 不能保证每 ...
- mysql 开启日志服务
mysql 版本:mysql-5.7 1.在/etc/my.cnf 中添加如下内容: #错误日志: -log-err log-error=/usr/local/mysql--linux-glibc2. ...