[模版]平衡树splay2
题目描述
输入
输出
若干行:每行1个整数,表示针对询问的回答,保证一定有合法的解
样例输入
样例输出
- #include<iostream>
- #include<cstdio>
- #include<cstring>
- #include<algorithm>
- #include<cmath>
- #include<cstdlib>
- #include<ctime>
- using namespace std;
- typedef long long ll;
- const int N=,INF=;
- struct node
- {
- node *child[],*fa;
- int x,mark,size,val;long long sum;
- }a[N];
- node *pos=a,*root,*newone;
- void check(node *r);
- void updata(node *&r)
- {
- if(r){
- r->sum=(r->child[]?r->child[]->sum:)+(r->child[]?r->child[]->sum:)+r->val;
- r->size=(r->child[]?r->child[]->size:)+(r->child[]?r->child[]->size:)+;
- }
- }
- void pushdown(node *&r)
- {
- if(!r || !r->mark)return ;
- if(r->child[])r->child[]->mark+=r->mark,r->child[]->sum+=(ll)r->mark*r->child[]->size,r->child[]->val+=r->mark;
- if(r->child[])r->child[]->mark+=r->mark,r->child[]->sum+=(ll)r->mark*r->child[]->size,r->child[]->val+=r->mark;
- updata(r);
- r->mark=;
- }
- void rotate(node *&r,bool t)//0left 1right
- {
- node *y=r->fa;
- pushdown(y);
- pushdown(r);
- y->child[!t]=r->child[t];
- if(r->child[t])r->child[t]->fa=y;
- if(y->fa)y->fa->child[y->fa->child[]==y]=r;
- r->fa=y->fa;
- r->child[t]=y;
- y->fa=r;
- updata(r);
- updata(y);
- updata(r->fa);
- }
- void splay(node *r,node *g)
- {
- while(r->fa!=g)
- {
- if(r->fa->fa==g)rotate(r,r->fa->child[]==r);
- else
- {
- node *y=r->fa;
- bool t=y->fa->child[]==y;
- if(y->child[t]==r)rotate(r,!t);
- else rotate(y,t);
- rotate(r,t);
- }
- }
- if(g==NULL)root=r;
- }
- void newnode(node *&r,int key,int val,node *fa)
- {
- r=pos++;
- r->fa=fa;
- r->child[]=r->child[]=NULL;
- r->x=key;r->val=val;r->mark=;r->size=;r->sum=val;
- }
- void insert(node *&r,int key,int val,node *fa)
- {
- if(r==NULL){
- newnode(r,key,val,fa);
- splay(r,NULL);
- return ;
- }
- else {
- pushdown(r);
- insert(r->child[key>r->x],key,val,r);
- }
- }
- node *pre,*nxt;
- void getpre(node *r,int key)
- {
- if(r==NULL)return ;
- if(r->x>=key)getpre(r->child[],key);
- else pre=r,getpre(r->child[],key);
- }
- void getnext(node *r,int key)
- {
- if(r==NULL)return ;
- if(r->x<=key)getnext(r->child[],key);
- else nxt=r,getnext(r->child[],key);
- }
- void work(int l,int r)
- {
- getpre(root,l);getnext(root,r);
- splay(pre,NULL);splay(nxt,pre);
- updata(root->child[]);updata(root);
- }
- void Delet(int l,int r)
- {
- work(l,r);
- root->child[]->child[]=NULL;
- updata(root->child[]);updata(root);
- }
- void add(int l,int r,int to)
- {
- work(l,r);
- root->child[]->child[]->mark+=to;
- root->child[]->child[]->sum+=(ll)to*root->child[]->child[]->size;
- root->child[]->child[]->val+=to;
- updata(root->child[]);updata(root);
- }
- long long ask(int l,int r)
- {
- work(l,r);
- node *y=root->child[]->child[];
- return y==NULL?:y->sum;
- }
- void haha()
- {
- insert(root,-INF,,NULL);
- insert(root,INF,,NULL);
- }
- int main()
- {
- freopen("pp.in","r",stdin);
- freopen("pp.out","w",stdout);
- haha();
- int n;
- char ch;int x,y,z;
- scanf("%d",&n);
- while(n--)
- {
- scanf("\n%c%d%d",&ch,&x,&y);
- if(ch=='I')insert(root,x,y,NULL);
- if(ch=='D')Delet(x,y);
- if(ch=='M'){
- scanf("%d",&z);
- add(x,y,z);
- }
- if(ch=='Q')printf("%lld\n",ask(x,y));
- }
- return ;
- }
[模版]平衡树splay2的更多相关文章
- hihocoder#1333 : 平衡树·Splay2 (区间操作)
题面: #1333 : 平衡树·Splay2 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:好麻烦啊~~~~~ 小Hi:小Ho你在干嘛呢? 小Ho:我在干活啊! ...
- Hihocoder #1333 : 平衡树·Splay2
1333 : 平衡树·Splay2 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:好麻烦啊~ 小Hi:小Ho你在干嘛呢? 小Ho:我在干活啊!前几天老师让我帮忙 ...
- hihocoder #1333 : 平衡树·Splay2
描述 小Ho:好麻烦啊~~~~~ 小Hi:小Ho你在干嘛呢? 小Ho:我在干活啊!前几天老师让我帮忙管理一下团队的人员,但是感觉好难啊. 小Hi:说来听听? 小Ho:事情是这样的.我们有一个运动同好会 ...
- 【hihocoder 1333】平衡树·Splay2
[题目链接]:http://hihocoder.com/problemset/problem/1333 [题意] [题解] 伸展树; 要求提供操作: 1.插入一个元素,两个权值,id作为查找的比较权值 ...
- Hihocoder 1333 (splay)
Problem 平衡树 splay2 题目大意 维护一个序列,支持四种操作: 操作1:添加一个数,编号为x,权值为y. 操作2:删除编号在区间[x,y]内的数. 操作3:将编号在区间[x,y]内的数的 ...
- tyvj 1729 文艺平衡树
文艺平衡树 From admin 背景 Background 此为平衡树系列第二道:文艺平衡树 描述 Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以 ...
- 3223: Tyvj 1729 文艺平衡树
3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1347 Solved: 724[Submit][Stat ...
- BZOJ3224普通平衡树【Splay】
3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 11751 Solved: 5013 Descriptio ...
- 平衡树初阶——AVL平衡二叉查找树+三大平衡树(Treap + Splay + SBT)模板【超详解】
平衡树初阶——AVL平衡二叉查找树 一.什么是二叉树 1. 什么是树. 计算机科学里面的树本质是一个树状图.树首先是一个有向无环图,由根节点指向子结点.但是不严格的说,我们也研究无向树.所谓无向树就是 ...
随机推荐
- 201621123068 Week03-面向对象入门
1. 本周学习总结 初学面向对象,会学习到很多碎片化的概念与知识.尝试学会使用思维导图将这些碎片化的概念.知识点组织起来.请使用工具画出本周学习到的知识点及知识点之间的联系.步骤如下: 1.1 写出你 ...
- faster-rcnn 结构杂谈
faster-rcnn结构图: (只截取了最难理解的部分) 这个网络看似很复杂,但是理解了其中关键的层,就基本可以掌握这个结构了.要看源码!!要看源码!!要看源码 !!重要的事情说三遍. 关键的层: ...
- JAVA_SE基础——59.权限访问修饰符
了解了包的概念,就可以系统的介绍Java中的访问控制级别.在Java中,针对类.成员方法和属性提供了四种访问级别,分别是private.default.protected和public. 权限访问修饰 ...
- URL编码和Base64编码 (转)
我们经常会遇到所谓的URL编码(也叫百分号编码)和Base64编码. 先说一下Bsae64编码.BASE64编码是一种常用的将二进制数据转换为64个可打印字符的编码,常用于在通常处理文本数据 ...
- ### Cause: org.apache.ibatis.binding.BindingException: Parameter 'name' not found. Available parameters are [arg1, arg0, param1, param2]
org.apache.ibatis.exceptions.PersistenceException: ### Error updating database. Cause: org.apache.ib ...
- mqtt paho ssl java端代码
参考链接:http://blog.csdn.net/lingshi210/article/details/52439050 mqtt 的ssl配置可以参阅 http://houjixin.blog.1 ...
- Spring知识点回顾(01)Java Config
Spring知识点回顾(01) 一.Java Config 1.服务和服务注入 2.Java 注解 :功能更强一些 3.测试验证 二.注解注入 1.服务和服务注入 2.配置加载 3.测试验证 三.总结 ...
- 云计算(2)it 是什么
2015年,全世界在it上面的花费达到3亿8千亿美金之多. 云数据中心:核心基础架构,云计算的物理载体,提供数据处理.存储和高性能计算支撑,包括服务器.存储.冷却.机房空间和能耗管理等. 超大规模的云 ...
- 一个适用于单页应用,返回原始滚动条位置的demo
如题,最近做一个项目时,由于页面太长,跳转后在返回又回到初始位置,不利于用户体验,需要每次返回到用户离开该页面是的位置.由于是移动端项目,使用了移动端的套ui框架framework7,本身框架的机制是 ...
- 复习HTML+CSS(3)
n 超级链接 l 语法格式:<a 属性 = "值">---</a> l 常用属性: n Href:目标文件的地址URL,该URL可以是相对地址,也可 ...