题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4348

题目大意:给定含有n个数的序列,有以下四种操作

1.C l r d:表示对区间[l,r]中的数加上d,并且时间加1

2.Q l r:询问当前时间区间[l,r]的和

3.H l r t:询问时间t区间[l,r]的和

4.B t :时间回到t

Sample Input

10 5
1 2 3 4 5 6 7 8 9 10
Q 4 4
Q 1 10
Q 2 4
C 3 6 3
Q 2 4
2 4
0 0
C 1 1 1
C 2 2 -1
Q 1 2
H 1 2 1
Sample Output
4
55
9
15

0
1

解题思路:用线段树求区间和时可以不用把lazy标记下传,因为每次都下传的话消耗的空间会很大,很可能爆内存,我们可以直接在询问时,把当前区间的懒惰标记用一个参数传下去,然后找到要求和的区间时,直接把从上到下的懒惰标记累加和乘以区间长度再加上这段区间原本的和就可以了。

代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=1e5+;
struct node{
int l,r;
ll lazy,sum;
}tree[maxn*];
int n,m,t,cnt,root[maxn];
void pushup(int rt,int l,int r){
tree[rt].sum=tree[tree[rt].l].sum+tree[tree[rt].r].sum+tree[rt].lazy*(r-l+);
}
void build(int &rt,int l,int r){
rt=++cnt;
tree[rt].lazy=;
if(l==r){
scanf("%lld",&tree[rt].sum);
return;
}
int mid=(l+r)/;
build(tree[rt].l,l,mid);
build(tree[rt].r,mid+,r);
pushup(rt,l,r);
}
void update(int &now,int pre,int L,int R,int val,int l,int r){
now=++cnt,tree[now]=tree[pre];
if(L<=l&&R>=r){
tree[now].sum+=1ll*(r-l+)*val;
tree[now].lazy+=val;
return;
}
int mid=(l+r)/;
if(L<=mid) update(tree[now].l,tree[pre].l,L,R,val,l,mid);
if(R>mid) update(tree[now].r,tree[pre].r,L,R,val,mid+,r);
pushup(now,l,r);
}
ll query(int now,int L,int R,int lazy,int l,int r){
if(L<=l&&R>=r){
return tree[now].sum+1ll*(r-l+)*lazy;
}
int mid=(l+r)/; ll res=;
lazy+=tree[now].lazy;
if(mid>=L) res+=query(tree[now].l,L,R,lazy,l,mid);
if(mid<R) res+=query(tree[now].r,L,R,lazy,mid+,r);
return res;
}
int main(){
char op[];
scanf("%d%d",&n,&m);
build(root[],,n);
int l,r,val,T;
t=;
while(m--){
scanf("%s",op);
if(op[]=='C'){
scanf("%d%d%d",&l,&r,&val);
t++;
update(root[t],root[t-],l,r,val,,n);
}else if(op[]=='Q'){
scanf("%d%d",&l,&r);
printf("%lld\n",query(root[t],l,r,,,n));
}else if(op[]=='H'){
scanf("%d%d%d",&l,&r,&T);
printf("%lld\n",query(root[T],l,r,,,n));
}else if(op[]=='B'){
scanf("%d",&t);
}
}
return ;
}

最新文章

  1. Android调用系统相机功能
  2. LINQ LINQ Operators and Lambda Expression - Syntax &amp; Examples
  3. SESSION机制
  4. iOS边练边学--多线程NSOperation介绍,子类实现多线程的介绍(任务和队列),队列的取消、暂停(挂起)和恢复,操作依赖与线程间的通信
  5. 在 WPF 程序中使用 MVVM 模式
  6. javascript之高级函数应用思想
  7. Android源码编译过程之九鼎开发板
  8. OTP语音芯片和掩模语音芯片(mask)的区别
  9. 3.请问配置JDK时环境变量path和JAVA_HOME的作用是什么?
  10. Bootstrap框架的要点--栅格系统
  11. mysql之连接localhost与127.0.0.1的区别
  12. 正则表达式过滤HTML、JS、CSS
  13. Python类的多态的例子
  14. 格式化数据保留两位小数,输入格式为 :xxx,xx,,,,x,,(x为浮点数)
  15. ZooKeeper 01 - 什么是ZooKeeper + 部署ZooKeeper集群
  16. Confluence 6 色彩选择器展开的页面
  17. IDEA 中javadoc插件不能设置的问题
  18. Oracle 性能调优
  19. 【WPF/C#】测试下载文件(图片)
  20. JavaScript:使用JavaScript 实现注册表单的校验

热门文章

  1. fengmiantu3
  2. onchange and oninput
  3. How to call javascript function on page load in asp.net
  4. element-ui的rules全局验证
  5. mysql group by 去重 分类 求和
  6. 【ABAP系列】SAP 生产订单完工确认(CO11N) BAPI : BAPI_PRODORDCONF_CREATE_TT
  7. 【ABAP系列】SAP 业务界面同时显示KEY和文本
  8. day16模块,导入模板完成的三件事,起别名,模块的分类,模块的加载顺序,环境变量,from...import语法导入,from...import *,链式导入,循环导入
  9. Monte Carlo Control
  10. python每日一练:0001题