传送门

对于这个题,显然要打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. nginx中常见的变量

    $arg_PARAMETER        客户端GET请求PARAMETER的值. $args     请求中的参数. $binary_remote_addr 二进制码形式的客户端地址. $body ...

  2. javascript回调函数那些事~

    什么是回调函数? 回调函数就是一个通过函数指针调用的函数.如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用为调用它所指向的函数时,我们就说这是回调函数.回调函数不是由该函数的实现方直 ...

  3. android studio 新建文件出错

  4. Java进化的尽头

    转载需声明:原文链接网址:http://www.artima.com/weblogs/viewpost.jsp?thread=221903 Java: Evolutionary Dead End 我在 ...

  5. PMP项目管理学习笔记(6)——整合管理之制订项目管理计划

    制订项目管理计划 输入:项目章程.组织过程资产.企业环境要素.计划过程的输出(): 工具:专家判断 输出:项目管理计划 项目管理计划使你在问题发生之前做出规划 你要在计划过程组中明确如何完成项目——因 ...

  6. 第17周翻译:SQL Server中的事务日志管理的阶梯:第5级:在完全恢复模式下管理日志

    来源:http://www.sqlservercentral.com/articles/Stairway+Series/73785/ 作者:Tony Davis, 2012/01/27 翻译:刘琼滨. ...

  7. 十分钟搭建App主流框架

    搭建主流框架界面 0.达成效果 Snip20150904_5.png 我们玩iPhone应用的时候,有没发现大部分的应用都是上图差不多的结构,下面的TabBar控制器可以切换子控制器,上面又有Navi ...

  8. dumpkeys - 转储显示键盘翻译表

    总览 (SYNOPSIS) dumpkeys [ -hilfn1 -Sshape -ccharset --help --short-info --long-info --numeric --full- ...

  9. uva1609 Foul Play

    思维 创造条件使一轮比赛之后仍满足1号打败至少一半,并剩下至少一个t' 紫书上的思路很清晰阶段1,3保证黑色至少消灭1半 #include<cstdio> #include<vect ...

  10. CAD交互绘制虚线(网页版)

    用户可以在CAD控件视区任意位置绘制直线. 主要用到函数说明: _DMxDrawX::DrawLine 绘制一个直线.详细说明如下: 参数 说明 DOUBLE dX1 直线的开始点x坐标 DOUBLE ...