splay树 序列终结者
/*
网上有许多题,就是给定一个序列,要你支持几种操作:A、B、C、D。一看另一道题,又是一个序列 要支持几种操作:D、C、B、A。尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术含量……这样 我也出一道题,我出这一道的目的是为了让大家以后做这种题目有一个“库”可以依靠,没有什么其他的意思。这道题目 就叫序列终结者吧。
给定一个长度为N的序列,每个序列的元素是一个整数(废话)。要支持以下三种操作: 1. 将[L,R]这个区间内的所有数加上V。 2. 将[L,R]这个区间翻转,比如1 2 3 4变成4 3 2 1。 3. 求[L,R]这个区间中的最大值。 最开始所有元素都是0。
第一行两个整数N,M。M为操作个数。 以下M行,每行最多四个整数,依次为K,L,R,V。K表示是第几种操作,如果不是第1种操作则K后面只有两个数。
对于每个第3种操作,给出正确的回答。*/
//splay树 第一次知道spaly树还可以这么玩,好开心。。。
//不过因为一个小错误调了半天。
#include<cstdio>
#include<iostream>
using namespace std;
int n,v[50005],shu[50005][2],fa[50005],m,size,sz[50005],mx[50005],root;
int he[50005],bi[50005];
void geng(int a1)
{
sz[a1]=sz[shu[a1][0]]+sz[shu[a1][1]]+1;
mx[a1]=max(mx[shu[a1][0]],mx[shu[a1][1]]);
mx[a1]=max(mx[a1],v[a1]);
return;
}
void roate(int a1,int &k)
{
int y=fa[a1],z=fa[y],l,r;
if(shu[y][0]==a1)
l=0;
else
l=1;
r=l^1;
if(y==k)
k=a1;
else
if(shu[z][0]==y)
shu[z][0]=a1;
else
shu[z][1]=a1;
fa[a1]=z;
shu[y][l]=shu[a1][r];
fa[shu[a1][r]]=y;
shu[a1][r]=y;
fa[y]=a1;
geng(a1);
geng(y);
return;
}
void splay(int &k,int a1)
{
for(;a1!=k;)
{
int y=fa[a1],z=fa[y];
if(y!=k)
if(shu[z][0]==y^shu[y][0]==a1)
roate(a1,k);
else
roate(y,k);
roate(a1,k);
}
}
void geng1(int a1)
{
int l=shu[a1][0],r=shu[a1][1];
if(he[a1])
{
if(l){mx[l]+=he[a1];v[l]+=he[a1];he[l]+=he[a1];}
if(r){mx[r]+=he[a1];v[r]+=he[a1];he[r]+=he[a1];}
he[a1]=0;
}
if(bi[a1])
{
bi[l]^=1;
bi[r]^=1;
bi[a1]=0;
swap(shu[a1][0],shu[a1][1]);
}
}
void jian(int a1,int a2,int a3)
{
if(a1>a2)
return;
if(a1==a2)
{
fa[a1]=a3;
if(a1<a3)
shu[a3][0]=a1;
else
shu[a3][1]=a1;
sz[a1]=1;
return;
}
int mid=(a1+a2)>>1;
fa[mid]=a3;
if(mid<a3)
shu[a3][0]=mid;
else
shu[a3][1]=mid;
jian(a1,mid-1,mid);
jian(mid+1,a2,mid);
geng(mid);
}
int find(int a1,int a2)
{
if(he[a1]||bi[a1])geng1(a1);
if(sz[shu[a1][0]]==a2-1)
return a1;
if(sz[shu[a1][0]]>=a2)
return(find(shu[a1][0],a2));
return(find(shu[a1][1],a2-sz[shu[a1][0]]-1));
}
void jia(int a1,int a2,int a3)
{
int x=find(root,a1);
int y=find(root,a2+2);
splay(root,x);
splay(shu[x][1],y);
int z=shu[y][0];
v[z]+=a3;
mx[z]+=a3;
he[z]+=a3;
return;
}
void fan(int a1,int a2)
{
int x=find(root,a1),y=find(root,a2+2);
splay(root,x);
splay(shu[x][1],y);
int z=shu[y][0];
bi[z]^=1;
return;
}
int zhao(int a1,int a2)
{
int x=find(root,a1),y=find(root,a2+2);
splay(root,x);
splay(shu[x][1],y);
int z=shu[y][0];
return mx[z];
}
int main()
{
mx[0]=-999999999;
scanf("%d%d",&n,&m);
jian(1,n+2,0);
root=(n+3)>>1;
for(int i=0;i<m;i++)
{
int a1,a2,a3,a4;
scanf("%d%d%d",&a1,&a2,&a3);
if(a1==1)
{
scanf("%d",&a4);
jia(a2,a3,a4);
}
if(a1==2)
fan(a2,a3);
if(a1==3)
printf("%d\n",zhao(a2,a3));
}
}
splay树 序列终结者的更多相关文章
- Splay模板(序列终结者)
我只是一个存模板的,详细的请看这里http://blog.csdn.net/whai362/article/details/47298133 题目链接:http://www.codevs.cn/pro ...
- BZOJ 1251 序列终结者(Splay)
题目大意 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术 ...
- 【bzoj1251】序列终结者(伸展树)
[bzoj1251]序列终结者(伸展树) Description 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我 ...
- BZOJ 1251: 序列终结者 [splay]
1251: 序列终结者 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 3778 Solved: 1583[Submit][Status][Discu ...
- 【BZOJ1251】序列终结者 Splay
一道模板题,一直没发现自己的快速读入读不了负数,我竟然能活到现在真是万幸. #include <iostream> #include <cstdio> #define inf ...
- 【BZOJ】1251: 序列终结者(splay)
http://www.lydsy.com/JudgeOnline/problem.php?id=1251 不行..为什么写个splay老是犯逗,这次又是null的mx没有赋值-maxlongint.. ...
- bzoj1251 序列终结者(Splay Tree+懒惰标记)
Description 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这 ...
- 「BZOJ1251」序列终结者 (splay 区间操作)
题面: 1251: 序列终结者 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 5367 Solved: 2323[Submit][Status][D ...
- 1251. 序列终结者【平衡树-splay】
Description 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这 ...
随机推荐
- PB之取下来列修改后的值(AcceptText)
AcceptText()功能 将“漂浮”在数据窗口控件上编辑框的内容放入到数据窗口控件的当前项中(主缓区中).在将数据放入到当前项之前,编辑框中的数据必须通过有效性规则检查语法 dwcontrol. ...
- NIO-FileChannel源码分析
目录 NIO-FileChannel源码分析 目录 前言 RandomAccessFile 接口 创建实例 获取文件通道 FileChannelImpl 创建 写文件 读文件 修改起始位置 获取文件长 ...
- IO是否会一直占用CPU?(转)
原文来自知乎:https://www.zhihu.com/question/27734728 这是一个很好的关于并发/并行系统的问题.简单回答就是:IO所需要的CPU资源非常少.大部分工作是分派给DM ...
- 伪静态 net-IIS伪静态配置,使用URLRewriter实现伪静态
https://www.cnblogs.com/zhenzaizai/p/10364343.html 前段时间开发公司官网,用到了URLRewriter实现伪静态,在VS调试模式下没有任何问题,部署到 ...
- python urllib应用
urlopen 爬取网页 爬取网页 read() 读取内容 read() , readline() ,readlines() , fileno() , close() :这些方法的使用方式与文件对象完 ...
- Pyspark:AssertionError: dataType should be DataType
1. schema参数,AssertionError: dataType should be DataType # AssertionError: dataType should be DataTyp ...
- SVN安装配置教程
第一步:安装Apache LInux centos6.5 (备注:为了方便可以把linux防火墙关掉,这样就不需要一个一个开端口了,建议开发测试可以这样,正式环境不推荐) 第二步:安装SVN服 ...
- synchronized关键字所生成的字节码详细分析
在之前已经将如下这样的源文件对应的字节码文件完整的分析完了,如下: 这次再来写一个内容稍丰富一点的类,准备再来从头至尾的来分析一下,对其字节码的理解进一步巩固,如下: 然后用javap -verbos ...
- P2341 [HAOI2006]受欢迎的牛[SCC缩点]
题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢"是可以传递的--如果A喜 欢B,B喜 ...
- JavaScript-Clipper.js
Clipper.js下载地址:https://sourceforge.net/projects/jsclipper/files/latest/download使用Javascript Clipper库 ...