传送门

对于这个题,显然要打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. MySQL与RAID

    RAID在mysq中适用场景 raid0:由于性能高和成本低,以及基本没有数据恢复的能力,而且它比单片磁盘损坏的概率要高.建议只在不担心数据丢失的情况下使用,如备库(slave)或者某些原因" ...

  2. Mysql选择合适的存储引擎

    Myisam:默认的mysql插件式存储引擎.如果应用是以读操作和插入操作为主,只有很少的更新和删除操作,并且对事务的完整性.并发性要求不是很高,那么选择这个存储引擎是非常合适的.Myisam是在we ...

  3. Windows下Apache应用环境塔建安全设置(目录权限设置)

    目的:为Apache,php配置受限制的用户权限.保护系统安全.需要的朋友可以参考下. 环境配置情况: apache安装目录:d:\www-s\apache php目录:d:\www-s\php5 m ...

  4. php,json数据传输(无刷新)

    废话不说直接上关键代码: js代码: <script language="javascript"> $(".login").live('click' ...

  5. RabbitMQ八:交换机类型Exchange Types--Topic介绍

    前言 上一章节,我们说了两个类型,本章我们说一下其三:Topic Exchange Topic Exchange  Topic Exchange – 将路由键和某模式进行匹配.此时队列需要绑定要一个模 ...

  6. [实用技巧] Mac下面如何通过终端快速打开当前文件夹

    Mac mac里面其实很简单,直接输入 open .,注意是open + 英文句点. Windows windows里面是start .,注意是start  + 英文句点.

  7. c# 移除数组为空元素

    通过字符串分割取得的数组中,有的时候可能需要处理除掉数组元素值为空的情况,所以可以按照如下代码完成: string rs="";//需要分割的字符串 char[] chspilt= ...

  8. UVA 11922 Permutation Transformer (Splay树)

    题意: 给一个序列,是从1~n共n个的自然数,接下来又m个区间,对于每个区间[a,b],从第a个到第b个从序列中分离出来,翻转后接到尾部.输出最后的序列. 思路: 这次添加了Split和Merge两个 ...

  9. Redhat5 安装序列号及版本说明

    为了保证安装的组件和订阅相匹配,红帽企业 Linux 5 需要输入一个安装号.它被用来配置安装程序来提供正确的软件包.安装号码包含在你的订阅里. 如果您没有输入安装号码,只有核心服务器或 Deskto ...

  10. 基于SAE的Python+Django部署

    本文主要参考:http://www.cnblogs.com/qtsharp/archive/2012/01/12/2320774.html,另外包括自己的实际操作. 一.申请SAE帐号以及创建应用ya ...