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.维护序列时始终记得 ...
随机推荐
- 【SQL】分析函数功能-排序
1:排名,不考虑并列问题 row_number() 2:排名,有并列,并列后的排名不连续 rank() 3:排名,有并列,并列后的排名连续 dense_rank() 测试: SQL> creat ...
- 【Linux】SecureCRT中按退格键出现^H
分两步: ①SecureCRT上部的“选项”→“会话选项”→终端→仿真→映射键→其他映射→Backspace发送delete(B) 勾选中,确定 ②SecureCRT上部的“选项”→全局选项→常规→默 ...
- 搞不懂的算法-排序篇<2>
上一篇排序算法<1>中,排序算法的时间复杂度从N2到NlgN变化,但他们都有一个共同的特点,基于比较和交换数组中的元素来实现排序,我们称这些排序算法为比较排序算法.对于比较排序算法,所有的 ...
- UWP 利用DataGrid控件创建表格
通过 Nuget 搜索 Microsoft.Toolkit.Uwp.UI.Controls.DataGrid 安装库,在XAML文件中添加引用库 xmlns:controls="using: ...
- 企业级任务调度框架Quartz(6) 任务调度器(Scheduler)
前序: 我们已经在前面的内容能里看到了,我们用 Scheduler 来管理我们的 Job:创建并关联触发器以使 Job 能被触发执行:以及如可选择 calendar 为给定的时程安排提供更多 ...
- java equals的用法
equals方法,用于比较两个对象是否相同,它其实就是使用两个对象的内存地址在比较.Object类中的equals方法内部使用的就是==比较运算符. package Xuexi; public cla ...
- 【数据分析学习】Pandas思维导图
点我查看原版
- Matrix(坑)
https://github.com/florent37/Android-3D-Layout
- mysql数据库重点监控
1. QPS 每秒钟查询数量 查询总数/秒数 queries per seconds show global status like 'Question%' 2.TPS 每秒钟的事物数 ...
- HDU5926 Mr. Frog’s Game
/* HDU5926 Mr. Frog’s Game http://acm.hdu.edu.cn/showproblem.php?pid=5926 杂题水题 * */ #include <cst ...