【动态规划17】bzoj3675 [Apio2014]序列分割(斜率优化)
来源:互联网 发布:js array find 编辑:程序博客网 时间:2024/06/05 07:28
为什么apio这么爱出斜率优化的题目..
题目描述
小H最近迷上了一个分隔序列的游戏。在这个游戏里,小H需要将一个长度为n的非负整数序列分割成k+1个非空的子序列。为了得到k+1个子序列,小H需要重复k次以下的步骤:
1.小H首先选择一个长度超过1的序列(一开始小H只有一个长度为n的序列——也就是一开始得到的整个序列);
2.选择一个位置,并通过这个位置将这个序列分割成连续的两个非空的新序列。
每次进行上述步骤之后,小H将会得到一定的分数。这个分数为两个新序列中元素和的乘积。小H希望选择一种最佳的分割方式,使得k轮之后,小H的总得分最大。
输入输出格式
输入第一行包含两个整数n,k(k+1≤n)。
第二行包含n个非负整数a1,a2,…,an(0≤ai≤10^4),表示一开始小H得到的序列。
输出第一行包含一个整数,为小H可以得到的最大分数。
f[i][p]表示前i个序列分割p次的最大得分
然而这道题bzoj卡内存,观察可以发现f[][k]的取值只与f[][k-1]相关,故循环队列。
转移到f[i][(p+1)&1]时,设
则
别忘了分母非0特判,由于题目中数字非负,所以如果前缀和相同的话,中间的一定都是0,对答案无影响,此时取j与取k效果是一样的。
#include<bits/stdc++.h>#define fer(i,j,n) for(int i=j;i<=n;i++)#define far(i,j,n) for(int i=j;i>=n;i--)#define ll long longconst int maxn=100010;const int INF=1e9+7;using namespace std;/*----------------------------------------------------------------------------*/inline ll read(){ char ls;ll x=0,sng=1; for(;ls<'0'||ls>'9';ls=getchar())if(ls=='-')sng=-1; for(;ls>='0'&&ls<='9';ls=getchar())x=x*10+ls-'0'; return x*sng;}/*----------------------------------------------------------------------------*/ll n,k;ll pre[maxn],f[maxn],g[maxn];int q[maxn];ll calcK(int j,int k){ if(pre[j]==pre[k])return 0; return (g[j]-g[k]-pre[j]*pre[j]+pre[k]*pre[k])/(pre[k]-pre[j]);}int main(){ n=read();k=read(); fer(i,1,n)pre[i]=read()+pre[i-1]; fer(i,1,k) { int h=0,t=0; fer(j,i,n) { while(h<t&&calcK(q[h],q[h+1])<pre[j])h++; f[j]=g[q[h]]+pre[q[h]]*(pre[j]-pre[q[h]]); while(h<t&&calcK(q[t-1],q[t])>calcK(q[t],j))t--; q[++t]=j; } fer(j,i,n)g[j]=f[j]; } cout<<f[n];}
- 【动态规划17】bzoj3675 [Apio2014]序列分割(斜率优化)
- [BZOJ3675][Apio2014]序列分割-斜率优化-动态规划
- bzoj3675 [APIO2014] 序列分割(斜率优化)
- 【BZOJ3675】[Apio2014]序列分割【斜率优化】
- BZOJ3675 [Apio2014]序列分割 斜率优化
- 【斜率优化】BZOJ3675(Apio2014)[序列分割]题解
- BZOJ3675 [Apio2014]序列分割 【斜率优化dp】
- 【BZOJ3675】序列分割(斜率优化,动态规划)
- [BZOJ3675][Apio2014]序列分割(斜率优化dp)
- 【bzoj3675】[Apio2014]序列分割 单调队列+斜率优化
- [bzoj3675] [Apio2014]序列分割 Split the sequence dp+斜率优化
- BZOJ 3675 [Apio2014]序列分割 动态规划+斜率优化
- [APIO2014]序列分割(斜率优化dp)
- APIO2014序列分割bzoj3675
- bzoj3675: [Apio2014]序列分割
- [BZOJ3675][Apio2014]序列分割
- [BZOJ3675] [Apio2014]序列分割
- bzoj3675【APIO2014】序列分割
- PHP正则
- POJ 2121 Inglish-Number Translator 笔记
- JavaScript之链式运动
- 高级软件工程课程理解及学习软件工程(C编码实践篇)的心得
- Python中yield使用解析
- 【动态规划17】bzoj3675 [Apio2014]序列分割(斜率优化)
- C++项目经验总结
- 硬盘无法访问 D:\参数不正确不丢失数据解决方法 [记录]
- cgroup资源隔离内存OOM事件监听(oom notifier)
- 数据预处理
- 使用LR做Doubbo接口的性能测试
- hadoop 处理二进制文件以查找海量图片中相同图片为例
- Mybatis 03 整合Spring+逆向工程
- java类的问题