就第三个操作比较新颖

转化成 在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维护序列的更多相关文章

  1. BZOJ 1251 Splay维护序列

    思路: splay维护序列的裸题 啊woc调了一天 感谢yzy大佬的模板-- //By SiriusRen #include <cstdio> #include <cstring&g ...

  2. BZOJ 3729 splay维护DFS序+博弈论

    思路: 这像是 阶梯Nim之类的东西 我们 直接把sg函数 设成mod(L+1)的 一棵子树 向下的奇数层上的石子xor起来 就是答案 有加点和改值的操作 就splay维护一下 //By Sirius ...

  3. BZOJ 3223 Tyvj 1729 文艺平衡树 | Splay 维护序列关系

    题解: 每次reverse(l,r) 把l-1转到根,r+1变成他的右儿子,给r+1的左儿子打个标记就是一次反转操作了 每次find和dfs输出的时候下放标记,把左儿子和右儿子换一下 记得建树的时候建 ...

  4. 【模板】splay维护序列

    题目大意:维护一个长度为 N 的序列,支持单点插入,单点询问. 注意事项如下: build 函数中要记得初始化 fa. 插入两个端点值. 代码如下 #include <bits/stdc++.h ...

  5. bzoj 1014 splay维护hash值

    被后缀三人组虐了一下午,写道水题愉悦身心. 题很裸,求lcq时二分下答案就行了,写的不优美会被卡时. (写题时精神恍惚,不知不觉写了快两百行...竟然调都没调就A了...我还是继续看后缀自动机吧... ...

  6. 洛谷 P2023 BZOJ 1798 [AHOI2009]维护序列

    题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...

  7. bzoj 1798 Seq 维护序列seq —— 线段树

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1798 这题还4A... 注意:cnt 从1开始:各种模 p:乘法标记初始值是 1:可能乘 0 ...

  8. Letters Removing CodeForces - 899F (线段树维护序列)

    大意: 给定字符串, 每次删除一段区间的某种字符, 最后输出序列. 类似于splay维护序列. 每次删除都会影响到后面字符的位置 可以通过转化为查询前缀和=k来查找下标. #include <i ...

  9. [BZOJ 1500] 维护序列

    Link: BZOJ 1500 传送门 Solution: 可能平衡树维护序列的所有操作都在这了吧…… 对序列的维护$fhq treap$和$Splay$都能做 有几个注意点: 1.维护序列时始终记得 ...

随机推荐

  1. MongoDB 博客截图之二

    使用内置帮助help() 基本命令示例 来源:MongoDB基本管理命令 - 千与的专栏 - 博客频道 - CSDN.NET

  2. 考考你对java多态的理解

    请看如下代码, 如果你能不运行得出正确答案, 那你真的超过99%的java程序员了. [本人属于最大头的那部分] public class A{ public String s = "A&q ...

  3. Java什么时候用static,public,private,protected?

    这么说吧,假如你是一个类: public表示你愿意其他人看见你的物品(字段.属性),或者你愿意帮别人做事(方法): private表示你不愿意其他任何人看见你的私人物品,也不愿意帮任何人做事: pro ...

  4. Bootstrap 4 - Glyphicons migration?

     https://stackoverflow.com/questions/32612690/bootstrap-4-glyphicons-migration Migrating from Glyphi ...

  5. Spring Boot 项目学习 (三) Spring Boot + Redis 搭建

    0 引言 本文主要介绍 Spring Boot 中 Redis 的配置和基本使用. 1 配置 Redis 1. 修改pom.xml,添加Redis依赖 <!-- Spring Boot Redi ...

  6. python二级登陆菜单

    """ 1.三级菜单 注册 登陆 注销 2.进入每一个一级菜单,都会有下一级的菜单"""user_item = dict()try: whi ...

  7. Python编码显示中文乱码

    爬虫时出现问题: import requests data=requests.get('http://roll.news.sina.com.cn/')print(data.text) 输出结果中文显示 ...

  8. 503是一种HTTP状态码。英文名503 Service Unavailable与404(404 Not Found)是同属一种网页状态出错码。前者是服务器出错的一种返回状态,后者是网页程序没有相关的结果后返回的一种状态,需要优化网站的时候通常需要制作404出错页以便网站整体优化。

    goldCat1 商城 消息 | 百度首页 新闻网页贴吧知道音乐图片视频地图百科文库 进入词条搜索词条帮助 近期有不法分子冒充官方收费编辑词条,百度百科严正声明:百科词条人人可编辑,词条创建和修改均免 ...

  9. windows电脑配置耳机只有一个耳朵响

    也许你在工作,需要一个耳朵听同事的声音,一个耳朵听电脑的音乐,但是又不想另一个耳机头泄露声音,这样就有了想配置只有左/右单个耳机头会响的操作. 那么我们就开始配置吧,我这里以win10为例: 右击桌面 ...

  10. 微信小程序 全局变量

    微信小程序里面有个app.js,我们可以在这个里面设置全局变量, App({ globalData:{ url:"http://xxx.xxx.xx:3000" } }) 在外面就 ...