#44. 【HNSDFZ2016 #6】可持久化线段树

统计

题目描述

现有一序列 AA。您需要写一棵可持久化线段树,以实现如下操作:

  • A v p x:对于版本v的序列,给 ApAp 增加 xx.
  • Q v l r:对于版本v的序列,询问 A[l,r]A[l,r] 的区间和。
  • C v:拷贝一份版本v的序列,编号为当前版本总数+1.

版本号从 11 开始;版本 11 的序列,所有元素均为 00.

格式

输入格式

第一行,两个正整数 n,mn,m,表示序列的长度和操作个数。

接下来 mm 行,每行输入一个操作,格式如题目描述所述。

保证任何输入的数都是正整数

输出格式

对于每一个Q操作,输出一行一个整数,表示对应的区间和。

样例数据

样例输入

5 5
A 1 2 3
Q 1 1 4
C 1
A 2 3 2
Q 2 1 4

样例输出

3
5

解释

第一次操作后,版本1的序列为:0 3 0 0 0.

第二次操作询问版本1的A[1,4]A[1,4]区间和,答案为0+3+0+0=30+3+0+0=3.

第三次操作将版本1的序列复制到版本2.

第四次操作后,版本2的序列为:0 3 2 0 0.

第五次操作询问版本2的A[1,4]A[1,4]区间和,答案为0+3+2+0=50+3+2+0=5.

数据规模与约定

对于20%20%的数据,有n≤1000,m≤100n≤1000,m≤100.

对于40%40%的数据,有n≤100000,m≤50000n≤100000,m≤50000.

对于100%100%的数据,有n≤1000000,m≤1500000n≤1000000,m≤1500000.

对于100%100%的数据,v,p,l,rv,p,l,r均合法;为了避免爆int,保证1≤x≤101≤x≤10.

时间限制:1s1s

空间限制:128MB

#include<cstdio>
using namespace std;
int read(){
register int x=,f=;
register char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
const int N=1.5e6+;
const int s=(<<);
struct node{int v,next;}e[N];
struct data{
int opt,ver,l,r;
}o[N];int cnt=,tot=;
int n,m,last[N],head[N],ans[N],t[s<<];
void add(int x,int y){
e[++tot]=(node){y,head[x]};head[x]=tot;
}
void updata(int x,int p){
for(x+=s;x;x>>=) t[x]+=p;
}
void del(int x,int p){
for(x+=s;x;x>>=) t[x]-=p;
}
inline int query(int l,int r){
int ret=;
for(l+=s-,r+=s+;l^r^;l>>=,r>>=){
if(!(l&)) ret+=t[l^];
if(r&) ret+=t[r^];
}
return ret;
}
void dfs(int x){
if(o[x].opt==) updata(o[x].l,o[x].r);
else if(o[x].opt==) ans[x]=query(o[x].l,o[x].r);
for(int i=head[x];i;i=e[i].next) dfs(e[i].v);
if(o[x].opt==) del(o[x].l,o[x].r);
}
int main(){
n=read();m=read();char s[];
last[]=;
for(int i=;i<=m;i++){
scanf("%s",s);o[i].ver=read();
if(s[]=='C') o[i].opt=;
else if(s[]=='A') o[i].opt=;
else o[i].opt=;
if(o[i].opt){
o[i].l=read();o[i].r=read();
add(last[o[i].ver],i);
last[o[i].ver]=i;
}
else{
add(last[o[i].ver],i);
last[++cnt]=i;
}
if(o[i].opt!=) ans[i]=-;
}
dfs();
for(int i=;i<=m;i++) if(ans[i]!=-) printf("%d\n",ans[i]);
return ;
}

PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树的更多相关文章

  1. 【bzoj4026】dC Loves Number Theory 可持久化线段树

    题目描述 dC 在秒了BZOJ 上所有的数论题后,感觉萌萌哒,想出了这么一道水题,来拯救日益枯竭的水题资源.  给定一个长度为 n的正整数序列A,有q次询问,每次询问一段区间内所有元素乘积的φ(φ(n ...

  2. (bzoj4408)[FJOI2016]神秘数(可持久化线段树)

    (bzoj4408)[FJOI2016]神秘数(可持久化线段树) bzoj luogu 对于一个区间的数,排序之后从左到右每一个数扫 如果扫到某个数a时已经证明了前面的数能表示[1,x],那么分情况: ...

  3. 【BZOJ-3673&3674】可持久化并查集 可持久化线段树 + 并查集

    3673: 可持久化并查集 by zky Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 1878  Solved: 846[Submit][Status ...

  4. 【BZOJ-2653】middle 可持久化线段树 + 二分

    2653: middle Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 1298  Solved: 734[Submit][Status][Discu ...

  5. HDU 4866 Shooting(持久化线段树)

    view code//第二道持久化线段树,照着别人的代码慢慢敲,还是有点不理解 #include <iostream> #include <cstdio> #include & ...

  6. 【BZOJ-3653】谈笑风生 DFS序 + 可持久化线段树

    3653: 谈笑风生 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 628  Solved: 245[Submit][Status][Discuss] ...

  7. 【BZOJ3673】&&【BZOJ3674】: 可持久化并查集 by zky 可持久化线段树

    没什么好说的. 可持久化线段树,叶子节点存放父亲信息,注意可以规定编号小的为父亲. Q:不是很清楚空间开多大,每次询问父亲操作后修改的节点个数是不确定的.. #include<bits/stdc ...

  8. 【BZOJ3207】花神的嘲讽计划I 可持久化线段树/莫队

    看到题目就可以想到hash 然后很自然的联想到可持久化权值线段树 WA:base取了偶数 这道题还可以用莫队做,比线段树快一些 可持久化线段树: #include<bits/stdc++.h&g ...

  9. 【BZOJ 3674】可持久化并查集加强版&【BZOJ 3673】可持久化并查集 by zky 用可持久化线段树破之

    最后还是去掉异或顺手A了3673,,, 并查集其实就是fa数组,我们只需要维护这个fa数组,用可持久化线段树就行啦 1:判断是否属于同一集合,我加了路径压缩. 2:直接把跟的值指向root[k]的值破 ...

随机推荐

  1. JVM学习(1)——通过实例总结Java虚拟机的运行机制

    俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及到的知识点总结如下: JVM的历史 JVM的运行流程简介 JVM的组成(基于 Java 7) JVM调优参数:-Xmx和-Xms ...

  2. Oracle 11.2.0.4单实例打PSU,OJVM PSU补丁快速参考

    写在前面: 1.Oracel打每个补丁的操作有时存在差异,所以不管多熟悉,都应该在打任何补丁之前阅读新补丁中附带的readme. 2.Oracle每季度都会更新一个最新的PSU,本文最新指的是当前最新 ...

  3. Vertica 分区表设计

    Vertica数据库中的表只是一个逻辑概念. 实际存储在磁盘上的是projection. 当创建一张表,没有创建projection时,那么插入数据的时候会自动创建一个默认的projection.如果 ...

  4. C#控制台程序取得INSOYA视频区的视频的真实URL,视频标题,发布时间集合。

    准备工作 起因是因为这个网站:http://i.youku.com/kmsfan 这个是一个叫做冒险岛的游戏的资讯论坛,以前我经常在里面传视频,现在我不玩这个游戏了,但是很多玩家还是经常到我的网站里面 ...

  5. ASP.NET Core 中文文档 第二章 指南(4.3)添加 View

    原文:Adding a view 作者:Rick Anderson 翻译:魏美娟(初见) 校对:赵亮(悲梦).高嵩(Jack).娄宇(Lyrics).许登洋(Seay).姚阿勇(Dr.Yao) 本节将 ...

  6. Bash简明教程--变量

    1. 前言 Bash是一门流行在*nix系统下的脚本语言.作为一门脚本语言,变量是一门语言的基本要素,在这篇教程中,我们将学习Bash中的变量是怎么表示的,以及变量相关的一些语法规则. 2. Bash ...

  7. 怎么调试lua性能

    怎么调试lua性能 我们的游戏使用的是Cocos2dx-lua 3.9的项目,最近发现我们的游戏.运行比较缓慢.想做一次性能优化了.其实主要分为GPU.CPU的分别优化.GPU部分的优化.网上有很多优 ...

  8. [转]在 .NET 中远程请求 https 内容时,发生错误:根据验证过程,远程证书无效

    该文原网址:http://www.cnblogs.com/xwgli/p/5487930.html 在 .NET 中远程请求 https 内容时,发生错误:根据验证过程,远程证书无效.   当访问 h ...

  9. 分布式文件系统 - FastDFS 在 CentOS 下配置安装部署

    少啰嗦,直接装 看过上一篇分布式文件系统 - FastDFS 简单了解一下的朋友应该知道,本次安装是使用目前余庆老师开源的最新 V5.05 版本,是余庆老师放在 Github 上的,和目前你能在网络上 ...

  10. GJM : Unity3D HIAR 目录导航

    感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...