可以平衡树或线段树维护斜率来做。还有一种线段树直接打标记的做法(李超线段树):线段树每个节点存一条线段作为标记,打标记时如果已有标记,则把占优区间小的那个线段下放。

#include<cstdio>
#include<algorithm>
#define N 50000
#define M (l+r>>1)
#define P (k<<1)
#define S (k<<1|1)
#define L l,M,P
#define R M+1,r,S
#define Z \
int l=0,int r=N-1,int k=1
using namespace std;
struct node{
double s,t;
double val(int x){
return s*x+t;
}
}e[N*2],*u=e,*a[N*4];
void apply(node*s,Z){
if(!a[k])a[k]=s;
else{
if(a[k]->val(M)<s->val(M))
swap(a[k],s);
if(l!=r)
a[k]->s<s->s?apply(s,R):apply(s,L);
}
}
double query(int s,Z){
double v=a[k]?a[k]->val(s):0;
if(l!=r)
v=max(v,s<=M?query(s,L):query(s,R));
return v;
}
int i,m;
char k[8];
double s,t;
int main(){
for(scanf("%d",&m);m;--m){
scanf("%s",k);
if(*k==80){
scanf("%lf%lf",&t,&s);
apply(&(*u++=(node){s,t}));
}
else{
scanf("%d",&i);
printf("%d\n",(int)query(i-1)/100);
}
}
}

之前写的是一个奇怪的做法……

答案序列一定是个下凸壳,因此添加的等差数列与其之差是个单峰函数,可以先三分求出最值,再二分求出零点,然后用线段树,将得到的区间修改为一个等差数列。

要降低复杂度的话可以把三分和二分写到线段树里面……

#include<cstdio>
#define Z \
int l=1,int r=N,int k=1
#define N 50000
#define M (l+r>>1)
#define P (k<<1)
#define S (k<<1|1)
#define K l,r,k
#define L l,M,P
#define R M+1,r,S
double a[N*4],b[N*4];
void devolve(Z){
if(b[k]){
a[S]=a[k]+(M-l+1)*(b[P]=b[S]=b[k]);
a[P]=a[k],b[k]=0;
}
}
double query(int s,Z){
if(l!=r){
devolve(K);
return s<=M?query(s,L):query(s,R);
}
return a[k];
}
void amend(double u,double v,int s,int t,Z){
if(s==l&&t==r)
a[k]=u,b[k]=v;
else{
devolve(K);
if(t<=M)
amend(u,v,s,t,L);
else if(s>M)
amend(u,v,s,t,R);
else{
amend(u,v,s,M,L);
amend(u+(M-s+1)*v,v,M+1,t,R);
}
}
}
double s,t;
int i,j,m,r,l;
char k[8];
void solve(){
scanf("%lf%lf",&s,&t);
l=1,r=N;
while(l!=r){
i=l+(r-l)/3;
j=r-(r-l)/3;
if(t*(i-j)<query(i)-query(j))
l=i+1;
else r=j-1;
}
if(s+t*l-t>query(l)){
r=l,l=1;
while(l!=r){
i=l+r>>1;
if(s+t*i-t>query(i))
r=i;
else l=i+1;
}
j=l,r=N;
while(l!=r){
i=l+r+1>>1;
if(s+t*i-t>query(i))
l=i;
else r=i-1;
}
amend(s+t*j-t,t,j,l);
}
}
int main(){
for(scanf("%d",&m);m;--m){
scanf("%s",k);
if(*k==80)
solve();
else{
scanf("%d",&i);
printf("%d\n",(int)query(i)/100);
}
}
}

最后吐槽一句这题啥破样例啊。

BZOJ1568: [JSOI2008]Blue Mary开公司的更多相关文章

  1. bzoj千题计划219:bzoj1568: [JSOI2008]Blue Mary开公司

    http://www.lydsy.com/JudgeOnline/problem.php?id=1568 写多了就觉着水了... #include<cstdio> #include< ...

  2. BZOJ1568: [JSOI2008]Blue Mary开公司【李超树】

    Description Input 第一行 :一个整数N ,表示方案和询问的总数. 接下来N行,每行开头一个单词"Query"或"Project". 若单词为Q ...

  3. 2019.02.11 bzoj1568: [JSOI2008]Blue Mary开公司(线段树)

    传送门 题意简述:维护整体加一条线段,求单点极值. 思路: 直接上李超线段树维护即可. 代码: #include<bits/stdc++.h> #define ri register in ...

  4. [bzoj1568][JSOI2008]Blue Mary开公司——李超线段树

    题目大意 题解 这道题需要用到一种叫做李超线段树的东西.我对于李超线段树,是这样理解的: 给节点打下的标记不进行下传,而是仅仅在需要的时候进行下传,这就是所谓永久化标记. 对于这道题,借用一张图, 这 ...

  5. 【BZOJ1568】[JSOI2008]Blue Mary开公司(李超线段树)

    [BZOJ1568][JSOI2008]Blue Mary开公司(李超线段树) 题面 BZOJ 洛谷 题解 是模板题啊. #include<iostream> #include<cs ...

  6. 【BZOJ1568】[JSOI2008]Blue Mary开公司 线段树

    [BZOJ1568][JSOI2008]Blue Mary开公司 Description Input 第一行 :一个整数N ,表示方案和询问的总数.  接下来N行,每行开头一个单词“Query”或“P ...

  7. 【BZOJ-1568】Blue Mary开公司 李超线段树 (标记永久化)

    1568: [JSOI2008]Blue Mary开公司 Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 557  Solved: 192[Submit ...

  8. 数据结构(线段树):BZOJ 1568 [JSOI2008]Blue Mary开公司

    1568: [JSOI2008]Blue Mary开公司 Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 602  Solved: 214[Submit ...

  9. [BZOJ 1568][JSOI2008]Blue Mary开公司

    [BZOJ 1568][JSOI2008]Blue Mary开公司 题意 \(n\) 次操作, 维护一个一次函数集合 \(S\). 有两种操作: 给定 \(b\) 和 \(k\), 向 \(S\) 中 ...

随机推荐

  1. 跨浏览器事件EventUtil

    <div style="width: 150px; height: 150px; padding: 25px; border:1px solid blue; " id=&qu ...

  2. Linux终端更改提示符

    打开~/.bashrc可以看到命令提示的内容为:\u@\h\w\$ \u表示用户名,\h表示主机名,\w表示当前目录,\$表示命令提示符(普通用户$,超级用户#) 这个命令提示符有点长,很碍事,\u@ ...

  3. void与void之间没有隐式转换(纯属恶搞,请勿在意)

    强大的vs弹出了这个提示:.有没有觉得强大的vs不应该出现该提示. 但就是出现了. 看客,您知道怎么让vs弹出这个提示吗^~^

  4. input用法,永远等待,直到用户输入值赋值给一个东西。

    input用法,永远等待,直到用户输入值赋值给一个东西. n1 = input('请输入用户名:') n1 = input('请输入密码:') print(n1) print(n1)

  5. git介绍

    简介:Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目.Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件.Git ...

  6. angular指令大全

    这篇文章的案例都是来自官方,引用的cdn来自bootcss, 因为angular的官方网站被屏了, 所以要翻, 不过我把整个文档下回来了,方便大家下载可以点击: 打开下载英文版 angular的指令 ...

  7. C#-WinForm-打印控件

    打印控件 绘制如下窗体 一.PrintDocument -打印的基础  首先放置PrintDocument控件,双击事件PrintPage设置要打印的样式(李献策lxc) //第一步 设置打印属性 p ...

  8. 如何破解Excel文档的编辑密码

    对于Excel文档我们不仅可以设置打开密码,还可以设置几天几种密码,比如编辑密码.编辑密码又称写保护密码,是一种可以限制编辑权限的密码.如果我们在日常工作中发现自己忘记了excel编辑密码的话,那就需 ...

  9. nginx--配置https服务器

    1.下载安装nginx: nginx可以从这里选择对应版本下载,我下载的是1.8.1版本.下载完成后,直接解压缩,命令窗口进入根目录,输入命令: start nginx 在浏览器中,直接输入" ...

  10. [Linux.NET] CentOS 开启/关闭端口

    最近一直在学习研究mvc网站部署到Linux上,Web服务器用的Jexus,linux版本是阿里云提供的centos.一个服务器又要放多个独立网站,对于学习阶段使用多个端口标识还是挺方便的,本文记录下 ...