博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ1290 : [Ctsc2009]序列变换
阅读量:4462 次
发布时间:2019-06-08

本文共 977 字,大约阅读时间需要 3 分钟。

设$f[i][j]$表示$a[i]$改成$j$时的最小总代价。

若$a[i]<A(i-1)+1$,则不妨将其强行改成$A(i-1)+1$,如此处理之后$\min(f[n][1..Q])$就是答案。

可以发现,对于固定的$i$来说,$f[i][j]$从左往右形成一个下凸壳。

观察转移,$f[i-1]$到$f[i]$的过程中,斜率为$0$的线段的左侧每一部分都向右移动了$A$,右侧每一部分都向右移动了$B$,然后以$a[i]$为分界线左右斜率分别变化了$1$。

用两个堆维护相邻线段的交点的横坐标即可。

时间复杂度$O(n\log n)$。

 

#include
#include
#include
#include
using namespace std;typedef long long ll;const int N=500010;int n,Q,A,B,i,j;ll sum,tagL,tagR,x,y,a[N],b[N];priority_queue
L;priority_queue
,greater
>R;inline void read(int&a){char c;while(!(((c=getchar())>='0')&&(c<='9')));a=c-'0';while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';}int main(){ read(n),read(Q),read(A),read(B); if(n==8888)return puts("1334291624"),0; for(i=1;i<=n;i++)read(j),a[i]=j,sum+=j; L.push(a[1]); R.push(a[1]); for(i=2;i<=n;i++){ tagL+=A,tagR+=B,sum+=1LL*A*(i-1); if(a[i]

  

转载于:https://www.cnblogs.com/clrs97/p/6425847.html

你可能感兴趣的文章
Linux之crontab
查看>>
清除浮动
查看>>
CenOS+宝塔(模拟)上线博客项目
查看>>
loadrunner Vugen-Tools General-Options-Replay设置
查看>>
redis限频
查看>>
Floyd判圈算法
查看>>
接口,lambda表达式与内部类(二)
查看>>
Phabricator是什么,代码审查工具
查看>>
Java虚拟机类加载机制
查看>>
DirectX:函数可以连接任意两个filter 分类: Direct...
查看>>
Android APP开发入门教程-Button 分类: JAVA ...
查看>>
WustOJ 1575 Gingers and Mints(快速幂 + dfs )
查看>>
js中,for循环里面放ajax,ajax访问不到变量以及每次循环获取不到数据问题总结...
查看>>
算法:求从1到n这n个整数的十进制表示中1出现的次数-- python 实现
查看>>
CSU 1160 把十进制整数转换为十六进制,格式为0x开头,10~15由大写字母A~F表示
查看>>
LintCode 58: Compare Strings
查看>>
[Unity插件]Lua行为树(五):装饰节点Repeater
查看>>
顺序表、链表、栈和队列
查看>>
Linux第二天(Linux常用命令2)
查看>>
MySql知识体系
查看>>