bzoj 1251 裸splay
裸的splay,只需要注意 max[-1]:=-maxlongint 就行了,否则在update的时候子节点的
max值会在max[-1]里选
/**************************************************************
Problem: 1251
User: BLADEVIL
Language: Pascal
Result: Accepted
Time:16008 ms
Memory:3448 kb
****************************************************************/
//By BLADEVIL
const
sroot =-1;
var
n, m :longint;
i :longint;
a, father :array[-1..100010] of longint;
k, l, r, v :longint;
root :longint;
max, size, tree :array[-1..100010] of longint;
val :array[-1..100010] of longint;
flag :array[-1..100010] of boolean;
son :array[-1..100010,0..1] of longint;
procedure swap(var a,b:longint);
var
c :longint;
begin
c:=a; a:=b; b:=c;
end;
function get_max(a,b:longint):longint;
begin
if a>b then exit(a) else exit(b);
end;
procedure renew_add(x,v:longint);
begin
inc(tree[x],v); inc(val[x],v); inc(max[x],v);
end;
procedure renew_reverse(x:longint);
begin
swap(son[x,1],son[x,0]);
flag[x]:=not flag[x];
end;
procedure update(x:longint);
begin
//if x=sroot then exit;
max[x]:=get_max(tree[x],get_max(max[son[x,1]],max[son[x,0]]));
size[x]:=size[son[x,1]]+size[son[x,0]]+1;
end;
function build(l,r:longint):longint;
var
mid :longint;
begin
mid:=(r+l) div 2;
build:=mid;
tree[mid]:=a[mid];
if l+1<=mid then
begin
son[mid,0]:=build(l,mid-1);
father[son[mid,0]]:=mid;
end;
if mid<=r-1 then
begin
son[mid,1]:=build(mid+1,r);
father[son[mid,1]]:=mid;
end;
update(mid);
end;
procedure push_down(x:longint);
var
l, r :longint;
begin
l:=son[x,0]; r:=son[x,1];
if flag[x] then
begin
if l<>-1 then renew_reverse(l);
if r<>-1 then renew_reverse(r);
flag[x]:=false;
end;
if val[x]<>0 then
begin
if l<>-1 then renew_add(l,val[x]);
if r<>-1 then renew_add(r,val[x]);
val[x]:=0;
end;
end;
function find(x:longint):longint;
var
t :longint;
begin
t:=root;
while true do
begin
push_down(t);
if size[son[t,0]]+1=x then exit(t);
if size[son[t,0]]+1>x then t:=son[t,0] else
begin
dec(x,size[son[t,0]]+1);
t:=son[t,1];
end;
end;
end;
procedure rotate(x,y:longint);
var
f :longint;
begin
push_down(x);
f:=father[x];
father[son[x,y xor 1]]:=f;
son[f,y]:=son[x,y xor 1];
if f=root then root:=x else
if f=son[father[f],0] then
son[father[f],0]:=x else
son[father[f],1]:=x;
father[x]:=father[f];
father[f]:=x;
son[x,y xor 1]:=f;
update(f);
update(x);
end;
procedure splay(x,y:longint);
var
u, v :longint;
begin
while father[x]<>y do
begin
if father[father[x]]=y then
rotate(x,ord(x=son[father[x],1])) else
begin
if son[father[x],0]=x then u:=1 else u:=-1;
if son[father[father[x]],0]=father[x] then v:=1 else v:=-1;
if u*v=1 then
begin
rotate(father[x],ord(x=son[father[x],1]));
rotate(x,ord(x=son[father[x],1]));
end else
begin
rotate(x,ord(x=son[father[x],1]));
rotate(x,ord(x=son[father[x],1]));
end;
end;
end;
update(x);
end;
procedure add(l,r,v:longint);
var
p :longint;
begin
p:=find(l);splay(p,sroot);
p:=find(r+2);splay(p,root);
p:=son[son[root,1],0];
renew_add(p,v);
end;
procedure reverse(l,r:longint);
var
p :longint;
begin
p:=find(l);splay(p,sroot);
p:=find(r+2);splay(p,root);
p:=son[son[root,1],0];
renew_reverse(p);
end;
function ask_max(l,r:longint):longint;
var
p :longint;
begin
p:=find(l); splay(p,sroot);
p:=find(r+2); splay(p,root);
p:=son[son[root,1],0];
ask_max:=max[p];
end;
begin
fillchar(son,sizeof(son),255);
read(n,m);
max[-1]:=-maxlongint;
for i:=1 to n do a[i]:=0;
inc(n);
root:=build(0,n);
father[root]:=sroot;
for i:=1 to m do
begin
read(k);
if k=1 then
begin
read(l,r,v);
add(l,r,v);
end else
begin
read(l,r);
if k=2 then
reverse(l,r) else
writeln(ask_max(l,r));
end;
end;
end.
bzoj 1251 裸splay的更多相关文章
- bzoj 3223 裸splay
裸的splay 今儿写的splay,由于自己刚开始学,发现几个容易漏掉的地方 1:开始给所有的儿子赋值为-1 2:给max[-1]赋值为-maxlongint 3:开始father[root]:=sr ...
- BZOJ 1251 序列终结者(Splay)
题目大意 网上有许多题,就是给定一个序列,要你支持几种操作: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 ...
- BZOJ 1251 Splay维护序列
思路: splay维护序列的裸题 啊woc调了一天 感谢yzy大佬的模板-- //By SiriusRen #include <cstdio> #include <cstring&g ...
- 序列终结者 BZOJ 1251 Splay
题目背景 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术 ...
- bzoj 1251序列终结者 splay 区间翻转,最值,区间更新
序列终结者 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 4594 Solved: 1939[Submit][Status][Discuss] De ...
- BZOJ 1251: 序列终结者
1251: 序列终结者 Time Limit: 20 Sec Memory Limit: 162 MB Submit: 3773 Solved: 1579 [Submit][Status][Dis ...
- bzoj 1251: 序列终结者 平衡树,fhqtreap
链接 https://www.lydsy.com/JudgeOnline/problem.php?id=1251 思路 好简单的模板题 不过还是wrong了好几发 叶子节点要注意下,不能使用 遇到就不 ...
- bzoj 1588 平衡树 splay
1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 15446 Solved: 6076[Submit][Sta ...
随机推荐
- Delphi7目录结构----初学者参考
打开Delphi的安装目录,如C:\Program Files\Borland\Delphi7,你将会看到目录下包含了一些文件和文件夹: ² Source:存放的是Delpi提供的所有源 ...
- 第十六篇 Python之迭代器与生成器
一.迭代器 一. 递归和迭代 生活实例说明什么是递归和迭代 A想去腾达大厦,问B怎么走路,B 说我不知道,我给你问问C,C也不知道,C又去问D,D知道,把路告诉了C,C又告诉B,B最后告诉A, 这就是 ...
- python 网络编程(socketserver,阻塞,其他方法)
重点回顾: (重点)粘包 : 就是因为接收端不知道如何接收数据,造成接收数据的混乱的问题 只发生在tcp协议上. 因为tcp协议的特点是面向数据流形式的传输 粘包的发生主要是因为tcp协议有两个机制: ...
- Spark集群管理器介绍
Spark可以运行在各种集群管理器上,并通过集群管理器访问集群中的其他机器.Spark主要有三种集群管理器,如果只是想让spark运行起来,可以采用spark自带的独立集群管理器,采用独立部署的模式: ...
- lintcode-135-数字组合
135-数字组合 给出一组候选数字(C)和目标数字(T),找到C中所有的组合,使找出的数字和为T.C中的数字可以无限制重复被选取. 例如,给出候选数组[2,3,6,7]和目标数字7,所求的解为: [7 ...
- Tomcat 中如何给 web 项目配置虚拟目录的方法
为什么要给 web 项目配置虚拟目录? 初学 JavaWeb 时,会发现只要我们把 web 项目放到 Tomcat 的 webapps 目录下,再通过 http://localhost:8080/项目 ...
- PHP蜘蛛爬虫开发文档
<我用爬虫一天时间“偷了”知乎一百万用户,只为证明PHP是世界上最好的语言 >所使用的程序框架 编写PHP网络爬虫, 需要具备以下技能: 爬虫采用PHP编写 从网页中抽取数据需要用XPat ...
- 算法(10)Subarray Sum Equals K
题目:在数组中找到一个子数组,让子数组的和是k. 思路:先发发牢骚,这两天做题是卡到不行哇,前一个题折腾了三天,这个题上午又被卡住,一气之下,中午睡觉,下午去了趟公司,竟然把namespace和cgr ...
- 【bzoj4817】[Sdoi2017]树点涂色 LCT+LCA+线段树
题目描述 给出一棵n个点,以1为根的有根树,每个点初始染有互不相同的颜色.定义一条路径的权值为路径上的颜色种类数.现有m次操作,每次操作为以下三种之一: 1 x: 把点x到根节点的路径上所有的点染上一 ...
- 【bzoj2049】[Sdoi2008]Cave 洞穴勘测 LCT
题目描述 辉辉热衷于洞穴勘测.某天,他按照地图来到了一片被标记为JSZX的洞穴群地区.经过初步勘测,辉辉发现这片区域由n个洞穴(分别编号为1到n)以及若干通道组成,并且每条通道连接了恰好两个洞穴.假如 ...