讲个笑话,这个题很休闲的。

大概是这样的,昨天看到这个题,第一眼星际把题目看反了然后感觉这是个傻逼题。

后来发现不对,这个修改一次的影响是很多的,可能导致一个数突然可以被改,也可能导致一个数不能被改。

大概就是一个不断拔高,最后拔得跟区间最大值一样高的过程。

后来开始想做法,感觉是不是可以维护一下最小的深度差,然后这个以内直接加,超过了就重构?

感觉似乎有点道理,写写写

自己想又感觉这个不太靠谱,可能会重构上天,然后就删了。

(flag++)

然后问了栋老师,栋老师一眼星际(跟我下午一样),然后忙着写集训队作业去了。

(天下神犇都神的相似,傻逼各有各的傻法)

后来问了lxl,挂张图:

他说的似乎有点道理,然而我没太弄懂他想表达什么

于是GG看其他题目去了。。。。。。

后来看了题解……

mdzz这不是我下午想的那个吗……?

然后想了下这个随机期望的复杂度,不太会,问了下栋老师,大概得到的结果是这样的:

首先分类讨论。

所以重构会在常数次,因此题解的复杂度是正确的~

然后谈一下维护:

由于变化会影响左右两边,所以维护一下左右两边的最小深度,每次在线段树上收集重构节点,大力计算就好。

#include<bits/stdc++.h>
#define lson (o<<1)
#define rson (o<<1|1)
const int N=;
const int inf=;
typedef long long ll;
inline int min(int x,int y){return x<y?x:y;}
using namespace std;
int n,m,a[N],exis[N],exl[N],exr[N],cnt,q[N];
ll sumv[N<<];int addv[N<<],minl[N<<],minr[N<<],size[N<<];
const int ch_top=4e7+;
typedef long long ll;
char ch[ch_top],*now_r=ch-,*now_w=ch-;
inline int read(){
while(*++now_r<'');
register int x=*now_r-'';
while(*++now_r>='')x=x*+*now_r-'';
return x;
}
inline void write(ll x){
static char st[];static int top;
while(st[++top]=''+x%,x/=);
while(*++now_w=st[top],--top);
*++now_w='\n';
}
inline void pushup(int o){
minr[o]=min(minr[lson],minr[rson]);
minl[o]=min(minl[lson],minl[rson]);
}
inline void puttag(int o,int v){
sumv[o]+=v*size[o];addv[o]+=v;minl[o]-=v;minr[o]-=v;
}
inline void pushdown(int o){
if(!addv[o])return;
puttag(lson,addv[o]);puttag(rson,addv[o]);
addv[o]=;
}
inline void build(int o,int l,int r){
if(l==r){
sumv[o]=a[l];size[o]=exis[l];minl[o]=exl[l];minr[o]=exr[l];
return;
}
int mid=(l+r)>>;
build(lson,l,mid);build(rson,mid+,r);
pushup(o);
sumv[o]=sumv[lson]+sumv[rson];
size[o]=size[lson]+size[rson];
}
inline void recalc(int o,int l,int r,int q){
if(l==r){
if(exis[l])a[l]+=addv[o];
addv[o]=;return;
}
pushdown(o);
int mid=(l+r)>>;
if(q<=mid)recalc(lson,l,mid,q);else recalc(rson,mid+,r,q);
}
inline ll querysum(int o,int l,int r,int ql,int qr){
if(ql<=l&&r<=qr)return sumv[o];
pushdown(o);
int mid=(l+r)>>;ll ans=;
if(ql<=mid)ans+=querysum(lson,l,mid,ql,qr);
if(qr>mid)ans+=querysum(rson,mid+,r,ql,qr);
return ans;
}
inline void change(int o,int l,int r,int ql,int qr){
if(ql<=l&&r<=qr)return void(puttag(o,));
pushdown(o);int mid=(l+r)>>;
if(ql<=mid)change(lson,l,mid,ql,qr);
if(qr>mid)change(rson,mid+,r,ql,qr);
pushup(o);
sumv[o]=sumv[lson]+sumv[rson];
}
inline void recexi(int o,int l,int r,int q){
if(l==r){
size[o]=exis[l];minl[o]=exl[l];minr[o]=exr[l];
return;
}
pushdown(o);int mid=(l+r)>>;
if(q<=mid)recexi(lson,l,mid,q);else recexi(rson,mid+,r,q);
pushup(o);
size[o]=size[lson]+size[rson];
}
inline void recml(int o,int l,int r,int q,int v){
if(l==r){minl[o]=v;return;}
pushdown(o);int mid=(l+r)>>;
if(q<=mid)recml(lson,l,mid,q,v);else recml(rson,mid+,r,q,v);
minl[o]=min(minl[lson],minl[rson]);
}
inline void recmr(int o,int l,int r,int q,int v){
if(l==r){minr[o]=v;return;}
pushdown(o);int mid=(l+r)>>;
if(q<=mid)recmr(lson,l,mid,q,v);else recmr(rson,mid+,r,q,v);
minr[o]=min(minr[lson],minr[rson]);
}
inline void dfs(int o,int l,int r){
if(minl[o]>&&minr[o]>=)return;
if(l==r){
if(minl[o]<=&&q[cnt]!=l)q[++cnt]=l;
if(minr[o]<)q[++cnt]=l+;
return;
}
pushdown(o);int mid=(l+r)>>;
dfs(lson,l,mid);dfs(rson,mid+,r);
}
inline bool flag(int i){return a[i-]>a[i];}
inline int calcl(int i){return exis[i]&&!exis[i-]?a[i-]-a[i]:inf;}
inline int calcr(int i){return exis[i]&&!exis[i+]?a[i+]-a[i]:inf;}
inline void calcexl(int i){if(i<||i>n)return;recml(,,n+,i,calcl(i));}
inline void calcexr(int i){if(i<||i>n)return;recmr(,,n+,i,calcr(i));}
inline void get(int i){if(i<||i>n)return;recalc(,,n+,i);}
inline void qwq(int i){
if(i<||i>n)return;get(i);get(i-);get(i+);exis[i]=flag(i);exl[i]=calcl(i);exr[i]=calcr(i);
recexi(,,n+,i);calcexl(i+);calcexr(i-);
}
int main(){
fread(ch,,ch_top,stdin);
n=read();m=read();
a[]=exl[]=exr[]=inf;a[n+]=exl[n+]=exr[n+]=inf;
for(int i=;i<=n;i++)a[i]=read(),exis[i]=flag(i);
for(int i=;i<=n;i++)exl[i]=calcl(i),exr[i]=calcr(i);
build(,,n+);
while(m--){
int opt=read(),x=read(),y=read();
if(opt==){
cnt=;change(,,n+,x,y);dfs(,,n+);
for(int i=;i<=cnt;i++)qwq(q[i]);
qwq(x);qwq(y+);
}
else{
write(querysum(,,n+,x,y));
}
}
fwrite(ch,,now_w-ch,stdout);
}

【bzoj5050】【bzoj九月月赛H】建造摩天楼的更多相关文章

  1. bzoj5050: 建造摩天楼

    Description 属于小Q管辖的n座摩天楼从左往右排成一排,编号依次为1到n,第i座摩天楼的高度为h_i.小Q会进行m次以下两种 操作之一: 2 l r,询问h_l+h_{l+1}+...+h_ ...

  2. bzoj 1600 &amp; Usaco 月赛 2008 建造栅栏 题解

    [原题] 1600: [Usaco2008 Oct]建造栅栏 Time Limit: 5 Sec  Memory Limit: 64 MB Submit: 785  Solved: 443 [Subm ...

  3. BZOJ 4070:[APIO2015]雅加达的摩天楼 最短路

    4070: [Apio2015]雅加达的摩天楼 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 464  Solved: 164[Submit][Sta ...

  4. BZOJ 1600: [Usaco2008 Oct]建造栅栏( dp )

    QAQ我没读过书...四边形都不会判定了 简单的dp.... --------------------------------------------------------------------- ...

  5. BZOJ 1600: [Usaco2008 Oct]建造栅栏

    1600: [Usaco2008 Oct]建造栅栏 Time Limit: 5 Sec  Memory Limit: 64 MB Description 勤奋的Farmer John想要建造一个四面的 ...

  6. 洛谷九月月赛II

    题解:模拟 一旦不匹配就要break #include<iostream> #include<cstdio> #include<cstring> #include& ...

  7. bzoj 4070 [Apio2015]雅加达的摩天楼 Dijkstra+建图

    [Apio2015]雅加达的摩天楼 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 644  Solved: 238[Submit][Status][D ...

  8. BZOJ 4070 [Apio2015]雅加达的摩天楼 ——分块 SPFA

    挺有趣的分块的题目. 直接暴力建边SPFA貌似是$O(nm)$的. 然后考虑分块,$\sqrt n$一下用虚拟节点辅助连边, 以上的直接暴力连边即可. 然后卡卡时间,卡卡空间. 终于在UOJ上T掉辣. ...

  9. BZOJ 1600 [Usaco2008 Oct]建造栅栏:dp【前缀和优化】

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1600 题意: 给你一个长度为n的木板,让你把这个木板切割成四段(长度为整数),并且要求这四 ...

随机推荐

  1. BZOJ 1924 所驼门王的宝藏(强连通分量缩点+DAG最长链)

    思路不是很难,因为宝藏只会在给出的n个点内有,于是只需要在这n个点里面连边,一个点如果能到达另一个点则连一条有向边, 这样用强连通分量缩点后答案就是DAG的最长链. 问题在于暴力建图是O(n^2)的, ...

  2. luogu 2115 破坏(01分数规划)

    题意:给出一个序列,删除一个连续的子串后使得剩下的平均值最小. 典型的01分数规划,令f(x)=(sum1[i]+sum2[j])/(i+j).sum1表示前缀和,sum2表示后缀和,那么我们就相当于 ...

  3. CODE FESTIVAL 2016 qualA Grid and Integers

    划年代久远的水 题意 有一个R*C的棋盘,要求在每个格子上填一个非负数,使得对任意一个2*2的正方形区域,左上角和右下角的数字之和等于左下角和右上角的数字之和.有一些格子已经被填上了数字,问现在能否满 ...

  4. 【codevs1163】访问艺术馆 树形dp

    题目描述 皮尔是一个出了名的盗画者,他经过数月的精心准备,打算到艺术馆盗画.艺术馆的结构,每条走廊要么分叉为二条走廊,要么通向一个展览室.皮尔知道每个展室里藏画的数量,并且他精确地测量了通过每条走廊的 ...

  5. debug - vue中通过ajax获取数据时,如何避免绑定的数据中出现property of undefined错误

    因为获取服务器是异步的,所以 vue 先绑定数据. 如果 ??? 是通过 ajax 异步获取的,在获取之前,???是未定义的.此时在外面的标签上添加一个 v-if="???" 可以 ...

  6. (三)MySQL学习笔记

    [Leecode]175. 组合两个表 解答:由于是组合两个表的信息,很容易想到连接查询,这里使用左连接 select p.Firstname,p.Lastname,q.City,q.State fr ...

  7. 菜鸟在线教你用Unity3D开发VR版的Hello World

    大家好,我是菜鸟在线的小编.这篇短文将告诉大家如何用Unity3D开发VR版的Hello World. 1开启SteamVR并连接Vive设备 (a)登录Steam客户端,并点击右上角的VR按钮,这时 ...

  8. 20135239益西拉姆 Linux内核分析 操作系统是怎样工作的?

    益西拉姆+ 原创作品+ <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 ” 堆栈 堆栈是C语言程序运行时 ...

  9. Function.caller, arguments.caller, arguments.callee, arguments.callee.calller

    Function.caller指向当前函数的调用者,是arguments.caller的替代者 arguments.caller也是指向当前函数的调用者,已被废弃 arguments.callee是对 ...

  10. requests、BeautifulSoup、自动登陆示例

    requests Python标准库中提供了:urllib.urllib2.httplib等模块以供Http请求,但是,它的 API 太渣了.它是为另一个时代.另一个互联网所创建的.它需要巨量的工作, ...