传送门

对于这个题,显然要打lazy标记了,但是lazy标记pushdown的时候肯定会增加一大堆节点,然后就MLE了。(题解这么说的,我其实不会pushdown)

所以,就换另一种方式,把标记直接打到当前区间,把当前区间的父亲节点大小都更新。求区间和的时候把沿途的标记都加起来就可以了。

注意分多钟情况。

——代码

 #include <cstdio>
#define ls son[now][0], l, mid
#define rs son[now][1], mid + 1, r
#define LL long long using namespace std; const int N = ; int n, m, tot;
int rt[N], son[N][], add[N];
LL sum[N]; inline void pushup(int now)
{
sum[now] = sum[son[now][]] + sum[son[now][]];
} inline void build(int &now, int l, int r)
{
now = ++tot;
add[now] = ;
if(l == r)
{
scanf("%lld", &sum[now]);
return;
}
int mid = (l + r) >> ;
build(ls);
build(rs);
pushup(now);
} inline void update(int &now, int l, int r, int last, int ql, int qr, int x)
{
now = ++tot;
add[now] = add[last];
sum[now] = sum[last];
son[now][] = son[last][];
son[now][] = son[last][];
sum[now] += (LL)x * (qr - ql + );
if(l == ql && r == qr)
{
add[now] += x;
return;
}
int mid = (l + r) >> ;
if(qr <= mid) update(ls, son[now][], ql, qr, x);
else if(ql > mid) update(rs, son[now][], ql, qr, x);
else
{
update(ls, son[now][], ql, mid, x);
update(rs, son[now][], mid + , qr, x);
}
} inline LL query(int now, int l, int r, int ql, int qr)
{
if(l == ql && r == qr) return sum[now];
int mid = (l + r) >> ;
LL ret = (LL)add[now] * (qr - ql + );
if(qr <= mid) return ret + query(ls, ql, qr);
else if(ql > mid) return ret + query(rs, ql, qr);
else return ret + query(ls, ql, mid) + query(rs, mid + , qr);
} int main()
{
int i, x, y, z, now;
bool f = ;
char s[];
while(~scanf("%d %d", &n, &m))
{
if(f) printf("\n");
else f = ;
now = tot = ;
build(rt[], , n);
for(i = ; i <= m; i++)
{
scanf("%s", s);
switch(s[])
{
case 'C': scanf("%d %d %d", &x, &y, &z); now++; update(rt[now], , n, rt[now - ], x, y, z); break;
case 'Q': scanf("%d %d", &x, &y); printf("%lld\n", query(rt[now], , n, x, y)); break;
case 'H': scanf("%d %d %d", &x, &y, &z); printf("%lld\n", query(rt[z], , n, x, y)); break;
case 'B': scanf("%d", &now); break;
}
}
}
return ;
}

[HDU4348]To the moon(主席树)的更多相关文章

  1. [HDU4348]To the moon(主席树+标记永久化)

    学可持久化treap的时候才发现自己竟然没写过需要标记下传的主席树,然而现在发现大部分操作都可以标记永久化,下传会增大占用空间. 这题一种写法是和普通的线段树一样标记下传,注意所有修改操作(包括put ...

  2. hdu4348 To the moon (主席树 || 离线线段树)

    Problem Description Background To The Moon is a independent game released in November 2011, it is a ...

  3. hdu 4348 To the moon (主席树区间更新)

    传送门 题意: 一个长度为n的数组,4种操作 : (1)C l r d:区间[l,r]中的数都加1,同时当前的时间戳加1 . (2)Q l r:查询当前时间戳区间[l,r]中所有数的和 . (3)H ...

  4. hdu 4348 To the moon (主席树)

    版权声明:本文为博主原创文章,未经博主允许不得转载. hdu 4348 题意: 一个长度为n的数组,4种操作 : (1)C l r d:区间[l,r]中的数都加1,同时当前的时间戳加1 . (2)Q ...

  5. HDU 4348 To the moon 主席树 在线更新

    http://acm.hdu.edu.cn/showproblem.php?pid=4348 以前做的主席树没有做过在线修改的题做一下(主席树这种东西正经用法难道不是在线修改吗),标记永久化比较方便. ...

  6. HDU 4348 To the moon 主席树

    题意: 给出一个长度为\(n(n \leq 10^5)\)的序列,最开始时间\(t=0\),支持下面几个操作: \(C \, l \, r \, d\):将区间\([l,r]\)每个数都加上\(d\) ...

  7. hdu 4348 To the moon 主席树区间更新

    To the moon Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Prob ...

  8. SP11470 TTM - To the moon[主席树标记永久化]

    SP11470 TTM - To the moon C l r d:区间 \([L,R]\) 中的数都加 d ,同时当前的时间戳加 1. Q l r:查询当前时间戳区间 \([L,R]\) 中所有数的 ...

  9. hdu4348区间更新的主席树+标记永久化

    http://acm.hdu.edu.cn/showproblem.php?pid=4348 sb的标记永久化即可,刚开始add和sum没复制过来wa了两发...,操作和原来的都一样,出来单点变成区间 ...

  10. HDU4348To the moon主席树,区间修改

    题意: 一个长度为n的数组,4种操作 : (1)C l r d:区间[l,r]中的数都加1,同时当前的时间戳加1 . (2)Q l r:查询当前时间戳区间[l,r]中所有数的和 . (3)H l r ...

随机推荐

  1. 【转】彻底解析Android缓存机制——LruCache

    彻底解析Android缓存机制——LruCache 关于Android的三级缓存,其中主要的就是内存缓存和硬盘缓存.这两种缓存机制的实现都应用到了LruCache算法,今天我们就从使用到源码解析,来彻 ...

  2. 【转】java序列化一定要应该注意的6个事项!

    1.如果子类实现Serializable接口而父类未实现时,父类不会被序列化,但此时父类必须有个无参构造方法,否则会抛InvalidClassException异常. 2.静态变量不会被序列化,那是类 ...

  3. iOS开发之cell位置contentOffset的用法

    @property(nonatomic)         CGPoint                      contentOffset;                  // default ...

  4. IOS之GCD记录

    在 GCD 中,加入了两个非常重要的概念: 任务 和 队列. 任务:即操作,你想要干什么,说白了就是一段代码,在 GCD 中就是一个 Block,所以添加任务十分方便.任务有两种执行方式: 同步执行 ...

  5. How `delete’ works ?

    这是2013年写的一篇旧文,放在gegahost.net上面 http://raison.gegahost.net/?p=21 February 16, 2013 How `delete’ works ...

  6. org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'needDao' defined in URL

    这个是我修改过后的mapper,是我的mapper中的空间地址写错了呢

  7. bitcoin 源码解析 - 交易 Transaction

    bitcoin 源码解析 - 交易 Transaction(三) - Script 之前的章节已经比较粗略的解释了在Transaction体系当中的整体运作原理.接下来的章节会对这个体系进行分解,比较 ...

  8. zuul 整理

    网关: 为了解决ip+端口的不友好性而产生.具有服务代理的功能nginx 功能: 1.验证与安全保障: 识别面向各类资源的验证要求并拒绝那些与要求不符的请求. 2.审查与监控: 在边缘位置追踪有意义数 ...

  9. Python3基础教程(十五)—— PEP8 代码风格指南

    编程语言不是艺术,而是工作或者说是工具,所以整理并遵循一套编码规范是十分必要的. 这篇文章原文实际上来自于这里:https://www.python.org/dev/peps/pep-0008/ 有很 ...

  10. this.treeData = JSON.parse(JSON.stringify(this.d)) 树的序列化反序列化

    this.treeData = JSON.parse(JSON.stringify(this.d))