CF573E (平衡树)
CF573E
题意概要
给出一个长度为\(n\)的数列,从中选出一个子序列\(b[1...m]\)(可以为空)
使得$$ \sum_{i=1}^m{b_i*i}$$最大,输出这个最大值。
其中\(n\le10^5\)
题解
设\(dp_{i,j}\)表示前\(i\)个数选择\(j\)个数的最大值
那么,转移方程则为:
\]
于是我们就得到了一个\(n^2\)的做法
我们考虑优化这个式子。
经\(dalao\)证明,发现总有存在一个分界线,这之前的取前者,这之后的取后者
大佬的证明在这里
我们二分分界线,然后用平衡树维护就好了
顺带一提,我今日方知\(splay\)没事多$ splay $几下还会变快
代码
#include<bits/stdc++.h>
#include<windows.h>
#define lch c[x][0]
#define rch c[x][1]
using namespace std;
typedef long long ll;
const int sz=1e5+7;
int n;
ll v,ans;
int rt,cnt;
int f[sz];
int c[sz][2];
int siz[sz];
ll val[sz],tag1[sz],tag2[sz];
inline int newnode(ll v){
int x=++cnt;
val[x]=v;
siz[x]=1;
return x;
}
inline void pushup(int x){
siz[x]=siz[lch]+siz[rch]+1;
}
inline void add(int x,ll tg1,ll tg2){
val[x]+=siz[lch]*tg1+tg2;
tag1[x]+=tg1;
tag2[x]+=tg2;
}
inline void pd(int x){
if(tag1[x]==0&&tag2[x]==0) return;
if(lch) add(lch,tag1[x],tag2[x]);
if(rch) add(rch,tag1[x],tag2[x]+(siz[lch]+1)*tag1[x]);
tag1[x]=0;
tag2[x]=0;
}
inline void pushdn(int x){
if(f[x]) pushdn(f[x]);
pd(x);
}
inline int get(int x){
return c[f[x]][1]==x;
}
inline void dfs(int x){
ans=max(ans,val[x]);
pd(x);
if(lch) dfs(lch);
if(rch) dfs(rch);
}
inline void rotate(int x){
int y=f[x],z=f[y],k=get(x),w=c[x][!k];
if(z) c[z][get(y)]=x;c[x][!k]=y;c[y][k]=w;
if(w) f[w]=y;if(y) f[y]=x;f[x]=z;
pushup(y);
}
inline void splay(int x,int t){
pushdn(x);
while(f[x]!=t){
int y=f[x];
if(f[y]!=t) rotate(get(x)^get(y)?x:y);
rotate(x);
}
pushup(x);
if(t==0) rt=x;
}
inline int find(int k){
int x=rt;
while(1){
pd(x);
if(siz[lch]+1==k) return x;
if(k<=siz[lch]) x=lch;
else k-=siz[lch]+1,x=rch;
}
}
inline void insert(int k,ll v){
int x=find(k-1);splay(x,0);
int y=find(k);splay(y,x);
c[y][0]=newnode(v);
f[c[y][0]]=y;
pushup(y);
pushup(x);
}
inline void modify(int l,int r,ll a,ll b){
int x=find(l-1);splay(x,0);
int y=find(r+1);splay(y,x);
add(c[y][0],a,b);
pushup(y);
pushup(x);
}
int main(){
scanf("%d",&n);
rt=newnode(0);
c[rt][0]=newnode(INT_MIN);
c[rt][1]=newnode(INT_MIN);
f[c[rt][0]]=f[c[rt][1]]=rt;
pushup(rt);
for(int i=1;i<=n;i++){
scanf("%lld",&v);
int l=2,r=i+1;
while(l<r){
int mid=(l+r)>>1;
if(val[find(mid)]+(mid-1)*v>=val[find(mid+1)]) r=mid;
else l=mid+1;
splay(find(mid),0);
}
int x=find(l);
ll y=val[x];
modify(l,i+1,v,v*(l-1));
insert(l,y);
}
dfs(rt);
printf("%lld\n",ans);
}
CF573E (平衡树)的更多相关文章
- [BZOJ3223]Tyvj 1729 文艺平衡树
[BZOJ3223]Tyvj 1729 文艺平衡树 试题描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区 ...
- [BZOJ3224]Tyvj 1728 普通平衡树
[BZOJ3224]Tyvj 1728 普通平衡树 试题描述 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除一个) ...
- BZOJ3223: Tyvj 1729 文艺平衡树 [splay]
3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3595 Solved: 2029[Submit][Sta ...
- [普通平衡树treap]【学习笔记】
3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 9046 Solved: 3840[Submit][Sta ...
- BZOJ 3224: Tyvj 1728 普通平衡树
3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 9629 Solved: 4091[Submit][Sta ...
- BZOJ 3223: Tyvj 1729 文艺平衡树
3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3628 Solved: 2052[Submit][Sta ...
- 【Splay】bzoj3223-Tyvj1729文艺平衡树
一.题目 Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 ...
- hiho #1329 : 平衡树·Splay
#1329 : 平衡树·Splay 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:小Hi,上一次你跟我讲了Treap,我也实现了.但是我遇到了一个关键的问题. ...
- bzoj 3196: Tyvj 1730 二逼平衡树
#include<cstdio> #include<ctime> #include<cstdlib> #include<iostream> #defin ...
随机推荐
- php链表笔记:合并两个有序链表
<?php /** * Created by PhpStorm. * User: huizhou * Date: 2018/12/2 * Time: 15:29 */ /** * 合并两个有序链 ...
- P1985 [USACO07OPEN]翻转棋
题目链接: 翻转棋 题目分析: 先状压/\(dfs\)枚举第一排状态,然后在每个\(1\)下面翻,即确定了第一排就确定了后面的状态 最后验证一下最后一排是不是全0即可 代码: #include< ...
- System.Web.Mvc.ValueProviderResult.cs
ylbtech-System.Web.Mvc.ValueProviderResult.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral ...
- day 42 01--CSS的引入方式及CSS选择器
01--CSS的引入方式及CSS选择器 本节目录 一 CSS介绍 二 行内样式 三 内接样式 四 外接样式 五 CSS的选择器 六 CSS的高级选择器 七 CSS的属性选择器 八 CSS的伪类选择 ...
- 2018-8-10-docfx-做一个和微软一样的文档平台
title author date CreateTime categories docfx 做一个和微软一样的文档平台 lindexi 2018-08-10 19:16:51 +0800 2018-2 ...
- No context type was found in the assembly
如果解决方法中有多个项目存在,记住要在默认项目中选择你需要的项目进行 enable-migrations add-migration 以及updatebase
- [转]Visual Studio 2010生成解决方案时,提示磁盘空间不足!
最近几天,使用VS调试时总是出现提示:磁盘空间不足.我觉得可能有两种可能: 1.系统盘已被木马侵袭.历时4小时的全盘扫描没有病毒提示,只好删除了一些不必要的软件: 2.使用VS2010调试 ...
- mac配置ls命令显示不同文件不同颜色
使用Mac看到Linux的Ubuntu终端显示的颜色是不是觉得很酷炫,是否很想自己也拥有一样变色技巧?不怕,我们也是可以的! . 打开配置文件 sudo vim ~/.bash_profile 写入以 ...
- Python ——tempfile
主要有以下几个函数: tempfile.TemporaryFile 如何你的应用程序需要一个临时文件来存储数据,但不需要同其他程序共享,那么用TemporaryFile函数创建临时文件是最好的选择.其 ...
- cgroups实验
# yum install -y libcgroup libcgroup-tools创建控制组cgcreate -g cpu:/testcgcreate -g cpu:/test2 禁用quotacg ...