记个板子,还是挺好用的。

 #include <bits/stdc++.h>
using namespace std;
char op[]; int rt,n,m,l,r,x,A,B,C,t;
struct O{
int l,r,x,m,o,s,v;
}a[];
void up(int u){
a[u].s=a[a[u].l].s+a[a[u].r].s+;
a[u].m=min(a[a[u].l].m,a[a[u].r].m);
a[u].m=min(a[u].m,a[u].v);
}
void build(int &u,int l,int r){
if (l>r) return;
u=l+r>>;
if (l<=r)
build(a[u].l,l,(l+r>>)-),
build(a[u].r,(l+r>>)+,r);
up(u);
}
void down(int u){
int l=a[u].l,r=a[u].r;
if (a[u].x){
if (l) a[l].x+=a[u].x,
a[l].m+=a[u].x,a[l].v+=a[u].x;
if (r) a[r].x+=a[u].x,
a[r].m+=a[u].x,a[r].v+=a[u].x;
a[u].x=;
}
if (a[u].o){
if (l) a[l].o^=,swap(a[l].l,a[l].r);
if (r) a[r].o^=,swap(a[r].l,a[r].r);
a[u].o=;
}
}
void split(int u,int k,int &l,int &r){
if (!k) {l=; r=u; return;}
if (k==a[u].s) {l=u; r=; return;}
down(u);
if (k<=a[a[u].l].s) r=u,split(a[u].l,k,l,a[u].l);
else l=u,split(a[u].r,k-a[a[u].l].s-,a[u].r,r);
up(u);
}
int merge(int l,int r){
if (!l||!r) return l+r;
if (1ll*rand()*(a[l].s+a[r].s)<1ll*RAND_MAX*a[l].s){
down(l); a[l].r=merge(a[l].r,r); up(l); return l;
}else{
down(r); a[r].l=merge(l,a[r].l); up(r); return r;
}
}
int main(){
scanf("%d",&n); a[].m=;
for (int i=;i<=n;++i)
scanf("%d",&a[i].v),a[i].m=a[i].v;
t=n; build(rt,,n);
scanf("%d",&m);
while (m--){
scanf("%s",op);
if (op[]=='A'){//add
scanf("%d%d%d",&l,&r,&x);
split(rt,r,B,C);
split(B,l-,A,B);
a[B].x+=x; a[B].m+=x; a[B].v+=x;
rt=merge(merge(A,B),C);
}else
if (op[]=='D'){//delete
scanf("%d",&x);
split(rt,x,B,C);
split(B,x-,A,B);
rt=merge(A,C);
}else
if (op[]=='M'){//min
scanf("%d%d",&l,&r);
split(rt,r,B,C);
split(B,l-,A,B);
printf("%d\n",a[B].m);
rt=merge(merge(A,B),C);
}else
if (op[]=='I'){//insert
scanf("%d%d",&l,&x);
split(rt,l,A,C);
a[++t].s=; a[t].m=a[t].v=x;
rt=merge(merge(A,t),C);
}else
if (op[]=='E'){//reverse
scanf("%d%d",&l,&r);
split(rt,r,B,C);
split(B,l-,A,B);
a[B].o^=; swap(a[B].l,a[B].r);
rt=merge(merge(A,B),C);
}else{//revolve
scanf("%d%d%d",&l,&r,&x);
x%=r-l+;
split(rt,r,B,C);
split(B,l-,A,B);
split(B,r-l+-x,l,r);
rt=merge(merge(A,r),merge(l,C));
}
}
return ;
}

Hanser!!

非旋treap (BZOJ1895)的更多相关文章

  1. [模板] 平衡树: Splay, 非旋Treap, 替罪羊树

    简介 二叉搜索树, 可以维护一个集合/序列, 同时维护节点的 \(size\), 因此可以支持 insert(v), delete(v), kth(p,k), rank(v)等操作. 另外, prev ...

  2. 非旋 treap 结构体数组版(无指针)详解,有图有真相

    非旋  $treap$ (FHQ treap)的简单入门 前置技能 建议在掌握普通 treap 以及 左偏堆(也就是可并堆)食用本blog 原理 以随机数维护平衡,使树高期望为logn级别, FHQ  ...

  3. 平衡树简单教程及模板(splay, 替罪羊树, 非旋treap)

    原文链接https://www.cnblogs.com/zhouzhendong/p/Balanced-Binary-Tree.html 注意是简单教程,不是入门教程. splay 1. 旋转: 假设 ...

  4. 2827: 千山鸟飞绝 非旋treap

    国际惯例的题面:看起来很不可做的样子,我们先来整理一下题意吧.就是,维护每个点曾经拥有过的最大的两个属性值,支持把点的位置移动.我们用map对每个位置进行离散化,对每个位置建立一个平衡树.为了方便分离 ...

  5. 2081.09.22 Kuma(非旋treap)

    描述 有N张卡片,编号从0到n-1, 刚开始从0到n-1按顺序排好. 现有一个操作, 对于p. l,表示从第p张卡片之后的l张卡片拿到 最前面. 例如n=7的时候, 刚开始卡片序列为0 1 2 3 4 ...

  6. 2018.08.27 rollcall(非旋treap)

    描述 初始有一个空集,依次插入N个数Ai.有M次询问Bj,表示询问第Bj个数加入集合后的排名为j的数是多少 输入 第一行是两个整数N,M 接下来一行有N个整数,Ai 接下来一行有M个整数Bj,保证数据 ...

  7. 2018.08.06 bzoj1500: [NOI2005]维修数列(非旋treap)

    传送门 平衡树好题. 我仍然是用的fhqtreap,感觉速度还行. 维护也比线段树splay什么的写起来简单. %%%非旋treap大法好. 代码: #include<bits/stdc++.h ...

  8. 2018.08.05 bzoj3223: Tyvj 1729 文艺平衡树(非旋treap)

    传送门 经典的平衡树问题,之前已经用splay写过一次了,今天我突发奇想,写了一发非旋treap的版本,发现挺好写的(虽然跑不过splay). 代码: #include<bits/stdc++. ...

  9. 2018.07.24 loj#107. 维护全序集(非旋treap)

    传送门 就是普通平衡树,可以拿来练非旋treap" role="presentation" style="position: relative;"&g ...

随机推荐

  1. 1861 奶牛的数字游戏 2006年USACO

    codevs——1861 奶牛的数字游戏 2006年USACO  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 青铜 Bronze 题解       题目描述 Descript ...

  2. solr 简要笔记

    创建搜索1 创建directory 2.分词器 analyzer 3indexwriter writer dic an 4.document doc.add writer.adddocument(do ...

  3. logistics regression

    logistics regression用于解决一些二分类问题.比如(纯假设)网上购物时,网站会判断一个人退货的可能性有多大,如果该用户退货的可能性很大,那么网站就不会推荐改用户购买退费险.反之,如果 ...

  4. 【Todo】Java学习笔记 100==100 & Reflection API & Optional类详解 & DIP、IoC、DI & token/cookie/session管理会话方式

    为什么1000 == 1000返回为False,而100 == 100会返回为True?   Link Java Reflection API:Link Java8 Optional 类深度解析: L ...

  5. ActiveMQ消息的延时和定时投递

    ActiveMQ对消息延时和定时投递做了很好的支持,其内部启动Scheduled来对该功能支持,也提供了一个封装的消息类型:org.apache.activemq.ScheduledMessage,只 ...

  6. 线性表的顺序存储和链式存储的实现(C)

    //线性表的顺序存储 #include <stdio.h>typedef int DataType;#define MaxSize 15//定义顺序表typedef struct { Da ...

  7. BUPT复试专题—哈夫曼树(2010)

    https://www.nowcoder.com/practice/162753046d5f47c7aac01a5b2fcda155?tpId=67&tqId=29635&tPage= ...

  8. CodeForces 321A Ciel and Robot(数学模拟)

    题目链接:http://codeforces.com/problemset/problem/321/A 题意:在一个二维平面中,開始时在(0,0)点,目标点是(a.b),问能不能通过反复操作题目中的指 ...

  9. TCP 的那些事儿(下)(转)

    TCP的RTT算法 从前面的TCP的重传机制我们知道Timeout的设置对于重传非常重要, 设长了,重发就慢,没有效率,性能差: 设短了,重发的就快,会增加网络拥塞,导致更多的超时,更多的超时导致更多 ...

  10. C#连接池

    C#数据库连接池 MySql SqlServer 查阅了一天的资料来学习MySql数据库连接池,终于在一篇博文上找到了,自己也整理了一下,希望对大家有用处 1. 建立连接池 1 using MySql ...