BZOJ 3323 splay维护序列
就第三个操作比较新颖
转化成 在l前插一个点
把r和r+1合并
//By SiriusRen
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int maxn=100005,mod=20130426;
typedef long long ll;
struct Tree{
int fa,ch[2];ll add,mul,size,val;
}tr[666666];
int cnt,root,n,xx,yy,zz;ll ans,t,al;
char op[10];
void push_up(int x){
int lson=tr[x].ch[0],rson=tr[x].ch[1];
tr[x].size=tr[lson].size+tr[rson].size+1;
}
void push_down(int x){
if(!x||(tr[x].mul==1&&tr[x].add==0))return;
int lson=tr[x].ch[0],rson=tr[x].ch[1];
((tr[lson].add*=tr[x].mul)+=tr[x].add)%=mod;
((tr[rson].add*=tr[x].mul)+=tr[x].add)%=mod;
((tr[lson].val*=tr[x].mul)+=tr[x].add)%=mod;
((tr[rson].val*=tr[x].mul)+=tr[x].add)%=mod;
(tr[lson].mul*=tr[x].mul)%=mod;
(tr[rson].mul*=tr[x].mul)%=mod;
tr[x].mul=1,tr[x].add=0;
}
int build(int l,int r,int father){
if(l>r)return 0;
int pos=++cnt;
tr[pos].size=1,tr[pos].fa=father,tr[pos].mul=1;
if(l==r)return pos;
int mid=(l+r)>>1;
tr[pos].ch[0]=build(l,mid-1,pos);
tr[pos].ch[1]=build(mid+1,r,pos);
push_up(pos);
return pos;
}
void rotate(int p){
int q=tr[p].fa,y=tr[q].fa,x=(tr[q].ch[1]==p);
tr[q].ch[x]=tr[p].ch[!x];tr[tr[q].ch[x]].fa=q;
tr[p].ch[!x]=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;
}
void dfs(int x){
if(!x)return;
push_down(x);
dfs(tr[x].ch[0]);
if(++al>0)(ans+=t*tr[x].val)%=mod,(t*=xx)%=mod;
dfs(tr[x].ch[1]);
}
int find(int x,int sz){
push_down(x);
if(tr[tr[x].ch[0]].size+1==sz)return x;
else if(tr[tr[x].ch[0]].size>=sz)return find(tr[x].ch[0],sz);
else return find(tr[x].ch[1],sz-tr[tr[x].ch[0]].size-1);
}
int main(){
scanf("%d",&n);
root=build(0,maxn,0);
while(n--){
scanf("%s",op);
if(op[0]=='a'){
scanf("%d%d%d",&xx,&yy,&zz);
int fx=find(root,xx+1),fy=find(root,yy+3);
splay(fx,0),splay(fy,fx);
(tr[tr[fy].ch[0]].add+=zz)%=mod,(tr[tr[fy].ch[0]].val+=zz)%=mod;
push_up(fy),push_up(fx);
}
else if(op[3]=='x'){
scanf("%d%d",&xx,&yy);
int fx=find(root,yy+1),fy=find(root,yy+4);
splay(fx,0),splay(fy,fx);
push_down(fx),push_down(fy),push_down(tr[fy].ch[0]);
int now1=tr[fy].ch[0],now2=tr[now1].ch[0]+tr[now1].ch[1];
tr[now1].val+=tr[now2].val,tr[now1].size=1;
tr[now2].fa=tr[now1].ch[0]=tr[now1].ch[1]=0;
push_up(fy),push_up(fx);
fx=find(root,xx+1),fy=find(root,xx+2);
splay(fx,0),splay(fy,fx);tr[fy].ch[0]=++cnt;
tr[cnt].size=1,tr[cnt].fa=fy,tr[cnt].mul=1;
push_up(fy),push_up(fx);
}
else if(op[0]=='q'){
scanf("%d",&xx),ans=0,t=1,al=-1,dfs(root),printf("%lld\n",ans);
}
else{
scanf("%d%d%d",&xx,&yy,&zz);
int fx=find(root,xx+1),fy=find(root,yy+3);
splay(fx,0),splay(fy,fx);
(tr[tr[fy].ch[0]].mul*=zz)%=mod,(tr[tr[fy].ch[0]].val*=zz)%=mod;
(tr[tr[fy].ch[0]].add*=zz)%=mod,push_up(fy),push_up(fx);
}
}
}
BZOJ 3323 splay维护序列的更多相关文章
- BZOJ 1251 Splay维护序列
思路: splay维护序列的裸题 啊woc调了一天 感谢yzy大佬的模板-- //By SiriusRen #include <cstdio> #include <cstring&g ...
- BZOJ 3729 splay维护DFS序+博弈论
思路: 这像是 阶梯Nim之类的东西 我们 直接把sg函数 设成mod(L+1)的 一棵子树 向下的奇数层上的石子xor起来 就是答案 有加点和改值的操作 就splay维护一下 //By Sirius ...
- BZOJ 3223 Tyvj 1729 文艺平衡树 | Splay 维护序列关系
题解: 每次reverse(l,r) 把l-1转到根,r+1变成他的右儿子,给r+1的左儿子打个标记就是一次反转操作了 每次find和dfs输出的时候下放标记,把左儿子和右儿子换一下 记得建树的时候建 ...
- 【模板】splay维护序列
题目大意:维护一个长度为 N 的序列,支持单点插入,单点询问. 注意事项如下: build 函数中要记得初始化 fa. 插入两个端点值. 代码如下 #include <bits/stdc++.h ...
- bzoj 1014 splay维护hash值
被后缀三人组虐了一下午,写道水题愉悦身心. 题很裸,求lcq时二分下答案就行了,写的不优美会被卡时. (写题时精神恍惚,不知不觉写了快两百行...竟然调都没调就A了...我还是继续看后缀自动机吧... ...
- 洛谷 P2023 BZOJ 1798 [AHOI2009]维护序列
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...
- bzoj 1798 Seq 维护序列seq —— 线段树
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1798 这题还4A... 注意:cnt 从1开始:各种模 p:乘法标记初始值是 1:可能乘 0 ...
- Letters Removing CodeForces - 899F (线段树维护序列)
大意: 给定字符串, 每次删除一段区间的某种字符, 最后输出序列. 类似于splay维护序列. 每次删除都会影响到后面字符的位置 可以通过转化为查询前缀和=k来查找下标. #include <i ...
- [BZOJ 1500] 维护序列
Link: BZOJ 1500 传送门 Solution: 可能平衡树维护序列的所有操作都在这了吧…… 对序列的维护$fhq treap$和$Splay$都能做 有几个注意点: 1.维护序列时始终记得 ...
随机推荐
- js 找数组中的最值
背景: 2个数组以下 , 比如 [[4, 9, 1, 3], [13, 35, 18, 26], [32, 35, 97, 39], [1000000, 1001, 857, 1]] 找最值的时候, ...
- JavaScript实现延时提示框
<html> <head> <meta charset="utf-8"> <title>无标题文档</title> &l ...
- Android 接入微信分享错误码-6
官方的常见错误表示签名出错登录以后,需要重装微信(也就是清除微信本地数据)
- android 自定义空间 组合控件中 TextView 不支持drawableLeft属性
android 自定义空间 组合控件中 TextView 不支持drawableLeft属性.会报错Caused by: android.view.InflateException: Binary X ...
- class A<T> where T:new()相关知识点
来源:http://www.cnblogs.com/FredWang/p/4284251.html class A<T> where T:new() ===>>> ...
- Http状态码大全(200、404、500等)
基本涵盖了所有问题 HTTP 400 – 请求无效HTTP 401.1 – 未授权:登录失败HTTP 401.2 – 未授权:服务器配置问题导致登录失败HTTP 401.3 – ACL 禁止访问资源H ...
- C#模拟按键
try { System.Threading.Thread.Sleep(); ; i < ; i++) { SendKeys.SendWait("{ENTER}"); Sen ...
- Asp.net Core 源码-UrlExtensions
using Microsoft.AspNetCore.Http; namespace SportsStore.Infrastructure { public static class UrlExten ...
- WIN 10 增删输入法
第一步: 任务栏右击 “语言——设置” 第二步: 第三步: 删除或者增加就好.
- qqbot 出现请求接口失败的问题
解决方法: 找到python安装目录下“Lib\site-packages\qqbot\qcontactdb\fetch.py”文件下的“http://s.web2.qq.com” 替换成 “http ...