2018.08.04 spoj TTM to the moon(主席树)
spoj传送门
vjudge传送门
主席树板子题。
支持历史版本的区间和,区间和,区间修改和时光倒流。
其中新奇一点的也只有区间修改了,这个东西直接标记永久化就行了。
如果想下传标记的话也行,需要在pushdown的时候新建一波节点。
代码:
#include<cstdio>
#include<cctype>
#define ll long long
#define N 100005
using namespace std;
inline ll read(){
ll ans=0,w=1;
char ch=getchar();
while(!isdigit(ch)){if(ch=='-')w=-1;ch=getchar();}
while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
return ans*w;
}
inline void write(ll x){
if(x<0)x=-x,putchar('-');
if(x>9)write(x/10);
putchar((x%10)^48);
}
inline ll max(ll a,ll b){return a>b?a:b;}
inline ll min(ll a,ll b){return a<b?a:b; }
int n,m,tot=0,rt[N*50],siz=0;
struct Node{int l,r;ll sum,add;}T[N*50];
inline void pushup(int p){T[p].sum=T[T[p].l].sum+T[T[p].r].sum;}
inline void build(int&p,int l,int r){
p=++tot;
if(l==r){T[p].sum=read();return;}
int mid=l+r>>1;
build(T[p].l,l,mid),build(T[p].r,mid+1,r),pushup(p);
}
inline void update(int&p,int las,int ql,int qr,int l,int r,ll v){
T[p=++tot]=T[las];
if(ql<=l&&r<=qr){T[p].add+=v;return;}
T[p].sum+=v*(min(qr,r)-max(ql,l)+1);
int mid=l+r>>1;
if(qr<=mid)update(T[p].l,T[las].l,ql,qr,l,mid,v);
else if(ql>mid)update(T[p].r,T[las].r,ql,qr,mid+1,r,v);
else update(T[p].l,T[las].l,ql,mid,l,mid,v),update(T[p].r,T[las].r,mid+1,qr,mid+1,r,v);
}
inline ll query(int p,int ql,int qr,int l,int r){
ll ret=T[p].add*(min(qr,r)-max(ql,l)+1);
if(ql<=l&&r<=qr)return T[p].sum+ret;
int mid=l+r>>1;
if(qr<=mid)return ret+query(T[p].l,ql,qr,l,mid);
if(ql>mid)return ret+query(T[p].r,ql,qr,mid+1,r);
return ret+query(T[p].l,ql,mid,l,mid)+query(T[p].r,mid+1,qr,mid+1,r);
}
int main(){
n=read(),m=read();
build(rt[0],1,n);
while(m--){
char op[2];
scanf("%s",op);
if(op[0]=='C'){int l=read(),r=read();ll v=read();++siz,update(rt[siz],rt[siz-1],l,r,1,n,v);}
if(op[0]=='Q'){int l=read(),r=read();printf("%lld\n",query(rt[siz],l,r,1,n));}
if(op[0]=='H'){int l=read(),r=read(),p=read();printf("%lld\n",query(rt[p],l,r,1,n));}
if(op[0]=='B')siz=read(),tot=rt[siz+1]-1;
}
return 0;
}
2018.08.04 spoj TTM to the moon(主席树)的更多相关文章
- SP11470 TTM - To the moon[主席树标记永久化]
SP11470 TTM - To the moon C l r d:区间 \([L,R]\) 中的数都加 d ,同时当前的时间戳加 1. Q l r:查询当前时间戳区间 \([L,R]\) 中所有数的 ...
- 新手C#string类常用函数的学习2018.08.04
ToLower()用于将字符串变为小写,注意字符串的不可变特性,需要重新赋值给另一个字符串变量. s = s.ToLower();//字符串具有不可变性,转换后需要重新赋值,不可仅有s.ToLower ...
- 新手C#int.Parse、int.TryParse的学习2018.08.04
int.Parse()用于将字符串转换为32为int类型,但是在遇到非数字或者类似1.545这种小数的时候会报错,后来采用了int.TryParse,这个在转换后会判断是否可以正常转换,若不能,会返回 ...
- 新手C#参数类型ref、out、params的学习2018.08.04
ref用于传递参数时,将实参传递到函数中,是引用参数,在使用前必须被赋值.string类型也同样适用. static void Main(string[] args) { string a1,a2; ...
- 新手C#重载、重写的学习2018.08.04
重载:在同一类(class)中,使用相同的方法名称,不同的参数和(不一定)不同的返回值类型构造成的方法. 举例: class OverLoadTest { public void Hello() { ...
- SPOJ 3267 D-query(离散化+主席树求区间内不同数的个数)
DQUERY - D-query #sorting #tree English Vietnamese Given a sequence of n numbers a1, a2, ..., an and ...
- SPOJ Count on a tree(主席树+LCA)
一.题目 COT - Count on a tree You are given a tree with N nodes. The tree nodes are numbered from 1 to ...
- SPOJ DQUERY D-query (在线主席树/ 离线树状数组)
版权声明:本文为博主原创文章,未经博主允许不得转载. SPOJ DQUERY 题意: 给出一串数,询问[L,R]区间中有多少个不同的数 . 解法: 关键是查询到某个右端点时,使其左边出现过的数都记录在 ...
- hdu4348 To the moon (主席树 || 离线线段树)
Problem Description Background To The Moon is a independent game released in November 2011, it is a ...
随机推荐
- PHP中间件--ICE
ICE(Internet Communications Engine)是Zeroc提供的一款高性能的中间件.使用ICE能使得php(或c++,java,python)与java,c++,.net,py ...
- 【转】Maven中-DskipTests和-Dmaven.test.skip=true的区别
主要区别是:是否编译测试类 -DskipTests:编译测试类,但不运行 -Dmaven.test.skip=true:不编译.不运行 转自 http://zephiruswt.blog.51cto. ...
- Spring MVC 重定向
@RequestMapping("/testRedirect") public String testRedirect(){ System.out.println("te ...
- Redis基本操作-string
Redis的5种数据结构:string.list.hash.set和zset; Redis 所有的数据结构都是以唯一的 key 字符串作为名称,然后通过这个唯一 key 值来获取相应的 value 数 ...
- 15 python re 模块
1.基础知识 正则表达式是用于处理字符串的强大工具,拥有自己独特的语法以及一个独立的处理引擎 正则表达式的大致匹配流程:依次拿出表达式和文本中的字符比较, 如果每一个字符都能匹配,则匹配成功:一旦有匹 ...
- 转载:MySQL和Redis 数据同步解决方案整理
from: http://blog.csdn.net/langzi7758521/article/details/52611910 最近在做一个Redis箱格信息数据同步到数据库Mysql的功能. 自 ...
- 读取数据库信息并生成表设计文档Word版本
1.参考C#代码 using Help.DBAccessLayer.Business; using Help.DBAccessLayer.Model.SqlGenerator; using Newto ...
- KEGG数据库介绍
转载自https://mp.weixin.qq.com/s/pqbMXMkuqEXbLf31PTxGZQ KEGG简介 KEGG 数据库于 1995 年由 Kanehisa Laboratories ...
- InnoDB FULLTEXT
1.概要 InnoDB引擎对FULLTEXT索引的支持是MySQL5.6新引入的特性,之前只有MyISAM引擎支持FULLTEXT索引.对于FULLTEXT索引的内容可以使用MATCH()…AGAIN ...
- 使用Font Awesome替换你的网站图标(icons 图标)
http://www.thinkcmf.com/font/icons/ 第一次使用 Font Awesome 发现相当的爽呀!它的图标很全,能够帮你节约时间去找图片.下面就来一起学习吧: 1: 去官方 ...