[模版]平衡树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. 什么是树. 计算机科学里面的树本质是一个树状图.树首先是一个有向无环图,由根节点指向子结点.但是不严格的说,我们也研究无向树.所谓无向树就是 ...
随机推荐
- cpp常用函数总结
//sprintf sprintf(temp_str_result, "%lf", temp_double); result = temp_str_result; (*begin) ...
- 201621123068 《Java程序设计》第1周学习总结
1. 本周学习总结 本周学习了如何使用Java来编写程序,还没展开学习具体的语言,但是也花了大量的时间搞清楚Java运行的原理.明白了Java是一种可以跨平台运行语言,搞清了jdk,jre,jvm之间 ...
- Flask 学习 九 用户资料
资料信息 app/models.py class User(UserMixin,db.Model): #...... name = db.Column(db.String(64)) location ...
- JAVA_SE基础——71.Random类制作随机验证码
public class Demo5 { public static void main(String[] args) { char[] arr={'s','b','g','h','a','c'}; ...
- 创建帧动画1 - xml方式
废话不多说,先看东西 创建帧动画1 - xml方式 帧动画的创建方式主要以下2种: * 用xml创建动画: * 用代码创建动画: 本文内容主要关注 xml文件 创建帧动画的方式 xml文件 ...
- api-gateway实践(01)服务网关 - 原型功能
一.服务注册 1.增加组:LsqGrpA 2.增加版本:LsqVerA 3.增加api:LsqApiA 3.1.基本信息 3.2.前端定义 3.3.后端定义 二.服务上线和服务授权 1.服务上线 2. ...
- Linux之Shell命令
开始接触Linux命令行,学习Linux文件系统导航以及创建.删除.处理文件所需的命令. 注:文末有福利! 几个快捷键: Linux发行版通常使用Ctrl+Alt组合键配合F1~F7进入要使用的控制 ...
- 19届华为实习生笔试之判断iPv6地址类型
题二: 答案: #coding=utf-8 import re,sys str = sys.stdin.readline().strip() def regex(str): result = &quo ...
- python之路1
python之路 http协议 html HTML2 CSS选择器 CSS属性操作 CSS属性操作/下 JavaScript(js)/上 JavaScript的对象 JavaScript的对象/下 前 ...
- 不错的ngix/redis/java/android学习地址
http://blog.csdn.net/xlgen157387/article/details/50051543 徐刘根的博客,好像是“Java后端技术”微信公众号的建立者,反正看到不少关于他的博文 ...