BZOJ 1500 splay终结版...
GSS系列有一丝丝像…
只不过那个是线段树 这个是splay
翻转 插入 删除啥的就是普通的splay
合在一起了而已
//By SiriusRen
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
struct Tree{
int v,rev,sum,lmax,rmax,maxx,ch[2],fa,size,same;
void init(){v=rev=sum=lmax=rmax=maxx=ch[0]=ch[1]=fa=0;size=1;same=-1001;}
}tr[505000];
int rubbish[500050],top,n,m,root;
char op[105];
void push_up(int x){
tr[0].init();tr[0].size=0,tr[0].maxx=-0x3f3f3f3f;
int lson=tr[x].ch[0],rson=tr[x].ch[1];
tr[x].size=tr[lson].size+tr[rson].size+1;
tr[x].sum=tr[lson].sum+tr[rson].sum+tr[x].v;
tr[x].lmax=max(max(tr[lson].lmax,tr[lson].sum+tr[rson].lmax+tr[x].v),0);
tr[x].rmax=max(max(tr[rson].rmax,tr[rson].sum+tr[lson].rmax+tr[x].v),0);
tr[x].maxx=max(tr[lson].maxx,max(tr[rson].maxx,tr[lson].rmax+tr[rson].lmax+tr[x].v));
}
void push_down(int x){
int lson=tr[x].ch[0],rson=tr[x].ch[1];
if(tr[x].same!=-1001){
tr[lson].same=tr[rson].same=tr[x].same;
tr[lson].v=tr[rson].v=tr[x].same;
tr[lson].sum=tr[lson].size*tr[x].same;
tr[rson].sum=tr[rson].size*tr[x].same;
if(tr[x].same>0){
tr[lson].maxx=tr[lson].lmax=tr[lson].rmax=tr[lson].sum;
tr[rson].maxx=tr[rson].lmax=tr[rson].rmax=tr[rson].sum;
}
else{
tr[lson].lmax=tr[lson].rmax=tr[rson].lmax=tr[rson].rmax=0;
tr[lson].maxx=tr[rson].maxx=tr[x].same;
}
tr[x].same=-1001;
}
if(tr[x].rev){
tr[lson].rev^=1,tr[rson].rev^=1;
swap(tr[x].ch[0],tr[x].ch[1]);
swap(tr[lson].lmax,tr[lson].rmax);
swap(tr[rson].lmax,tr[rson].rmax);
tr[x].rev=0;
}
}
void rotate(int p){
int q=tr[p].fa,y=tr[q].fa,f=(tr[q].ch[1]==p);
tr[q].ch[f]=tr[p].ch[!f];tr[tr[q].ch[f]].fa=q;
tr[p].ch[!f]=q;tr[q].fa=p;tr[p].fa=y;
if(y)tr[y].ch[tr[y].ch[1]==q]=p;
push_up(q);
}
void splay(int x,int tp){
for(int y;y=tr[x].fa;rotate(x)){
if(y==tp)break;
if(tr[y].fa!=tp){
if((tr[y].ch[0]==x)^(tr[tr[y].fa].ch[0]==y))rotate(x);
else rotate(y);
}
}push_up(x);
if(!tp)root=x;
}
int newnode(){
int temp=rubbish[top--];tr[temp].init();
return temp;
}
int build(int l,int r,int fa){
if(l>r)return 0;
if(l==r){
int temp=newnode();
scanf("%d",&tr[temp].v);
tr[temp].maxx=tr[temp].sum=tr[temp].v;
tr[temp].lmax=tr[temp].rmax=max(0,tr[temp].v);
tr[temp].fa=fa;
return temp;
}
int mid=(l+r)>>1;
int temp=newnode();
tr[temp].ch[0]=build(l,mid-1,temp);
scanf("%d",&tr[temp].v);
tr[temp].maxx=tr[temp].sum=tr[temp].v;
tr[temp].lmax=tr[temp].rmax=max(0,tr[temp].v);
tr[temp].fa=fa;
tr[temp].ch[1]=build(mid+1,r,temp);
push_up(temp);
return temp;
}
void check(int x){
push_down(x);
printf("x=%d lson=%d rson=%d sum=%d size=%d maxx=%d v=%d lmax=%d rmax=%d\n",x,tr[x].ch[0],tr[x].ch[1],tr[x].sum,tr[x].size,tr[x].maxx,tr[x].v,tr[x].lmax,tr[x].rmax);
if(tr[x].ch[0])check(tr[x].ch[0]);
if(tr[x].ch[1])check(tr[x].ch[1]);
}
int find(int x,int y){
push_down(x);
if(tr[tr[x].ch[0]].size+1==y)return x;
if(tr[tr[x].ch[0]].size>=y)return find(tr[x].ch[0],y);
else return find(tr[x].ch[1],y-tr[tr[x].ch[0]].size-1);
}
void dfs_del(int x){
if(x)rubbish[++top]=x;
if(tr[x].ch[0])dfs_del(tr[x].ch[0]);
if(tr[x].ch[1])dfs_del(tr[x].ch[1]);
}
int main(){
top=500000;
for(int i=1;i<=500000;i++)rubbish[i]=i;
scanf("%d%d",&n,&m);
root=build(1,n,0);
int tempa=find(root,1),tempb=newnode();
splay(tempa,0);
tr[tempa].ch[0]=tempb;tr[tempb].fa=tempa;
push_up(tempa);
tempa=find(root,n+1),tempb=newnode();
splay(tempa,0);
tr[tempa].ch[1]=tempb,tr[tempb].fa=tempa;
push_up(tempa);
while(m--){
scanf("%s",op);
int xx,yy,zz;
if(op[0]=='I'){
scanf("%d%d",&xx,&yy);
tempa=find(root,xx+1);
splay(tempa,0);
tempb=find(root,xx+2);
splay(tempb,tempa);
int newroot=build(1,yy,tempb);
tr[tempb].ch[0]=newroot;
push_up(tempb);push_up(root);
}
else if(op[0]=='D'){
scanf("%d%d",&xx,&yy);
tempa=find(root,xx);
splay(tempa,0);
tempb=find(root,xx+1+yy);
splay(tempb,tempa);
dfs_del(tr[tempb].ch[0]);
tr[tempb].ch[0]=0;push_up(tempb);push_up(tempa);
}
else if(op[2]=='K'){
scanf("%d%d%d",&xx,&yy,&zz);
tempa=find(root,xx);
splay(tempa,0);
tempb=find(root,xx+1+yy);
splay(tempb,tempa);
tr[tr[tempb].ch[0]].same=tr[tr[tempb].ch[0]].v=zz;
push_down(tr[tempb].ch[0]),push_up(tr[tempb].ch[0]);
push_up(tempb),push_up(tempa);
}
else if(op[0]=='R'){
scanf("%d%d",&xx,&yy);
tempa=find(root,xx);
splay(tempa,0);
tempb=find(root,xx+1+yy);
splay(tempb,tempa);
tr[tr[tempb].ch[0]].rev^=1;
swap(tr[tr[tempb].ch[0]].lmax,tr[tr[tempb].ch[0]].rmax);
push_up(tempb);
}
else if(op[0]=='G'){
scanf("%d%d",&xx,&yy);
tempa=find(root,xx);
splay(tempa,0);
tempb=find(root,xx+1+yy);
splay(tempb,tempa);
printf("%d\n",tr[tr[tempb].ch[0]].sum);
}
else{
tempa=find(root,1);
splay(tempa,0);
tempb=find(root,tr[root].size);
splay(tempb,tempa);
printf("%d\n",tr[tr[tempb].ch[0]].maxx);
}
}
}
BZOJ 1500 splay终结版...的更多相关文章
- BZOJ 1500 Splay 全操作
好久没写splay了,写一发(写了一节课,调了一节课) #include <iostream> #include <cstring> #include <cstdio&g ...
- [BZOJ 1500] [NOI2005] 维修数列
题目链接:BZOJ - 1500 题目分析 我要先说一下,这道题我写了一晚上,然后Debug了一整个白天..........再一次被自己的蒟蒻程度震惊= = 这道题是传说中的Splay维护数列的Bos ...
- [BZOJ 1500] 维护序列
Link: BZOJ 1500 传送门 Solution: 可能平衡树维护序列的所有操作都在这了吧…… 对序列的维护$fhq treap$和$Splay$都能做 有几个注意点: 1.维护序列时始终记得 ...
- IOS之UI--小实例项目--添加商品和商品名(使用xib文件终结版) + xib相关知识点总结
添加商品和商品名小项目(使用xib文件终结版) 小贴士:博文末尾有项目源码在百度云备份的下载链接. xib相关知识点总结 01-基本使用 一开始使用xib的时候,如果要使用自定义view的代码,就需要 ...
- Qt Windows下链接子系统与入口函数(终结版)(可同时存在main和WinMain函数)
Qt Windows下链接子系统与入口函数(终结版) 转载自:http://blog.csdn.net/dbzhang800/article/details/6358996 能力所限,本讨论仅局限于M ...
- coursera_poj_魔兽世界终结版
五个下午的时间!!!!终于过了!!有史以来做的最复杂的一个题这是我迄今为止做的最复杂也最具有挑战的一个oj作业.虽然之前做过比这个规模一些作业项目,但是往往有简单的模块框架,模块之前的关系也只是有些简 ...
- 蜻蜓特派员 Windows XP SP3 纯净终结版
蜻蜓特派员Windows XP SP3 纯净安装版 终结版,系统纯净无广告.无插件,网卡等驱动和运行库齐全,安全更新补丁全网最新!微软停止了 Windows XP 的支持之后还是偶尔为 WinXP 提 ...
- [转]springcloud(九):配置中心和消息总线(配置中心终结版)
https://www.cnblogs.com/ityouknow/p/6931958.html springcloud(九):配置中心和消息总线(配置中心终结版) 我们在springcloud(七) ...
- SQL Server数据全同步及价值分析[终结版]
SQL Server数据全同步[终结版] 版权全部.转载请注明出处.谢谢! 经过两天的同步编写和測试.出了第一个Release版本号: 1. 本函数仅支持单向同步.即从一个主数据库想多个从数据库同步 ...
随机推荐
- myslide探索
最近查一些国内学术牛人的报告时,注意到myslide是个很好的平台,比如山大一个老师的报告,完全可以在上面看到 https://myslide.cn/slides/10774 又比如交大一个大牛老师关 ...
- classname在JavaScript中的应用
<html> <head> <meta charset="utf-8"> <title>无标题文档</title> &l ...
- 更改 AVD 默认存放位置
AVD Manager 创建的 Android 模拟器(AVD)默认存放位置为C:\Users\<user>\.android\avd,我创建了2个AVD,一共用了近9G!是要挪挪地方了. ...
- DataTable的Select()方法
DataRow[] partno = dtPack.Select("PK_SOHEAD = " + pk_sohead + " AND PART_NO = '" ...
- Segment公司--整合数据进行分析
YC毕业生Segment获得1500万美元A轮融资 现在收集数据是每一个公司的必修课了,而且是从各种不同 API 上收集数据,但是你还要把这些数据整合起来才能发挥作用,Segment就能帮你整合各个平 ...
- 时空上下文视觉跟踪(STC)
论文的关键点是对时空上下文(Spatio-Temporal Context)信息的利用.主要思想是通过贝叶斯框架对要跟踪的目标和它的局部上下文区域的时空关系进行建模,得到目标和其周围区域低级特征的统计 ...
- matplotlib学习笔记.CookBook
matplotlib 是Python下的一个高质量的画图库,可以简单的类似于MATLAB方法构建高质量的图表. 原始文章地址:http://zanyongli.i.sohu.com/blog/view ...
- Spring依赖注入:@Autowired,@Resource和@Inject区别与实现原理
一.spring依赖注入使用方式 @Autowired是spring框架提供的实现依赖注入的注解,主要支持在set方法,field,构造函数中完成bean注入,注入方式为通过类型查找bean,即byT ...
- 10件5G能实现,但4G不能做的事情
10件5G能实现,但4G不能做的事情 从三星Galaxy S10 5G手机到OnePlus 7 Pro 5G手机以及更高版本,首批5G手机现已上市.5G网络时代的开启是从小范围内,如果你居住在可以使用 ...
- win7不需要密码访问网络共享文件(转载)
大家是不是觉得,共享一个文件夹后,每次输入密码都很麻烦呢?有没有不需要输入密码就可以访问共享文件的方法呢? 答案是肯定的,当然有,下面介绍下win7不需要密码访问网络共享文件 工具/原料 两台电脑在局 ...