2018年全国多校算法寒假训练营练习比赛(第五场)H Tree Recovery
Tree Recovery
空间限制:C/C++ 131072K,其他语言262144K
64bit IO Format: %lld
题目描述:进行区间求和,区间加减(线段树加懒惰标记)
输入
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
输出
4
55
9
15
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn = +;
long long a[maxn];
struct node
{
long long l,r;
long long date,add;
} T[maxn*];
long long n,m;
long long ans=;
void build(long long v,long long l,long long r)
{
T[v].l=l,T[v].r=r;
if(l==r)
{
T[v].date=a[l];
return ;
}
long long mid = (l+r)>>;
build(v<<,l,mid);
build(v<<|,mid+,r);
T[v].date=T[v<<].date+T[v<<|].date;
}
void add(long long v,long long l,long long r,long long value)
{
T[v].date+=(r-l+)*value;
if(T[v].l==l&&T[v].r==r)
{
T[v].add+=value;
return ;
}
if(T[v].add)
{
T[v<<].date+=(T[v<<].r-T[v<<].l+)*T[v].add;
T[v<<|].date+=(T[v<<|].r-T[v<<|].l+)*T[v].add;
T[v<<].add+=T[v].add;
T[v<<|].add+=T[v].add;
T[v].add=;
}
long long mid=(T[v].l+T[v].r)>>;
if(r<=mid)
{
add(v<<,l,r,value);
}
else
{
if(l>mid)
{
add(v<<|,l,r,value);
}
else
{
add(v<<,l,mid,value);
add(v<<|,mid+,r,value);
}
}
}
void query(long long v,long long l,long long r)
{
if(T[v].l==l&&T[v].r==r)
{
ans+=T[v].date;
return ;
}
if(T[v].add)
{
T[v<<].date+=(T[v<<].r-T[v<<].l+)*T[v].add;
T[v<<|].date+=(T[v<<|].r-T[v<<|].l+)*T[v].add;
T[v<<].add+=T[v].add;
T[v<<|].add+=T[v].add;
T[v].add=;
}
long long mid = (T[v].l+T[v].r)>>;
if(r<=mid)
{
query(v<<,l,r);
}
else
{
if(l>mid)
query(v<<|,l,r);
else
{
query(v<<,l,mid);
query(v<<|,mid+,r);
}
}
}
int main()
{
scanf("%lld%lld",&n,&m);
for(int i=; i<=n; i++)scanf("%lld",&a[i]);
build(,,n);
while(m--)
{
char s[];
long long x,y,z;
scanf("%s",s);
if(s[]=='Q')
{
scanf("%lld%lld",&x,&y);
ans=;
query(,x,y);
printf("%lld\n",ans);
}
else
{
scanf("%lld%lld%lld",&x,&y,&z);
add(,x,y,z);
}
}
return ;
}
2018年全国多校算法寒假训练营练习比赛(第五场)H Tree Recovery的更多相关文章
- 【2018年全国多校算法寒假训练营练习比赛(第五场)-E】情人节的电灯泡(二维树状数组单点更新+区间查询)
试题链接:https://www.nowcoder.com/acm/contest/77/E 题目描述 情人节到了,小芳和小明手牵手,打算过一个完美的情人节,但是小刚偏偏也来了,当了一个明晃晃的电灯泡 ...
- 2018年全国多校算法寒假训练营练习比赛(第一场)闯关的lulu
闯关的lulu 链接:https://www.nowcoder.com/acm/contest/67/J 来源:牛客网 题目描述 勇者lulu某天进入了一个高度10,000,000层的闯关塔,在塔里每 ...
- 2018年全国多校算法寒假训练营练习比赛(第一场)D N阶汉诺塔变形
https://www.nowcoder.com/acm/contest/67/D 思路: 先手动模拟一下过程,以下是模拟过程,按顺序表示第几步需要移动的盘标号 1 1 2 1 1 2 1 1 3 1 ...
- 2018年全国多校算法寒假训练营练习比赛(第一场)E 恋与程序员
https://www.nowcoder.com/acm/contest/67/E 思路: dfs 代码: #include<bits/stdc++.h> using namespace ...
- 2018年全国多校算法寒假训练营练习比赛(第一场)G 圆圈
https://www.nowcoder.com/acm/contest/67/G 思路: 分形. 记录中间左边点的坐标,然后推出另外3个点的坐标,递归到最简单的情况. 代码: #include< ...
- 2018年全国多校算法寒假训练营练习比赛(第一场)C 六子冲
https://www.nowcoder.com/acm/contest/67/C 思路: 模拟. 代码: #include<bits/stdc++.h> using namespace ...
- 2018年全国多校算法寒假训练营练习比赛(第二场)B - TaoTao要吃鸡
链接:https://www.nowcoder.com/acm/contest/74/B来源:牛客网 题目描述 Taotao的电脑带不动绝地求生,所以taotao只能去玩pc版的荒野行动了, 和绝地求 ...
- 2018年全国多校算法寒假训练营练习比赛(第二场)F - 德玛西亚万岁
链接:https://www.nowcoder.com/acm/contest/74/F来源:牛客网 题目描述 德玛西亚是一个实力雄厚.奉公守法的国家,有着功勋卓著的光荣军史. 这里非常重视正义.荣耀 ...
- 2018年全国多校算法寒假训练营练习比赛(第一场)J - 闯关的lulu
链接:https://www.nowcoder.com/acm/contest/67/J来源:牛客网 题目描述 勇者lulu某天进入了一个高度10,000,000层的闯关塔,在塔里每到一层楼,他都会获 ...
- 吐泡泡(2018年全国多校算法寒假训练营练习比赛(第二场)+栈模拟)+Plug-in(codeforces81A+栈模拟)
吐泡泡题目链接:https://www.nowcoder.com/acm/contest/74/A 题目: 思路: 这种题目当初卡了我很久,今天早训时遇到一个一样得题,一眼就想到用栈模拟,就又回来把这 ...
随机推荐
- 【iOS】this class is not key value coding-compliant for the key ...
一般此问题 都是由 interface build 与代码中 IBOutlet 的连接所引起的. 可能是在代码中对 IBOutlet 的名称进行了修改,导致 interface build 中的连接实 ...
- Linq查找最大值max最小值min效率比较
对linq查找极值的几种方法做一个效率上的比较 // 首先创建了一个10_000_000大小的PointF列表 var rdn = new Random(); var points = Enumera ...
- 夯实Java基础(九)——final关键字
1.前言 Java语言中的final关键字,想必大家都不是很陌生,我们自己用的最多的应该是用来定义常量吧,那么今天我们就来了解final这个关键字的用法,这个关键字还是非常简单的. final从字面意 ...
- Ok-Http | Android 网络请求框架使用方式
POST : package he3.sd.util; import com.parkingwang.okhttp3.LogInterceptor.LogInterceptor; import jav ...
- C#实现简单爬虫
分享之前写过的一个爬虫,采集数据,存入数据库的简单实现. github地址:https://github.com/CodesCreator/biu-biu-biu-
- print('', end='')
print函数的end参数,从python3才开始支持,所以如果要使用这种模式,需要对应使用python3
- 武林 HDU - 1107
题目链接:https://vjudge.net/problem/HDU-1107 注意:题目中只有两个不同门派的人在同一个地方才能对决,其他情况都不能对决. 还有,这步的有效的攻击只有走到下一步之后才 ...
- Struts1.x 跨站脚本(XSS)漏洞的解决
一. 演示XSS 当访问一个不存在的网址时,例如[url]http://localhost:8080/demo/noAction.do[/url],那么Struts处理后都会跳到提示“Invali ...
- intellIJ IDEA学习笔记3
intellij idea 的快捷鍵 https://blog.csdn.net/wei83523408/article/details/60472168 https://www.cnblogs.co ...
- 8.9 day30 并发编程 进程理论 进程方法 守护进程 互斥锁
多道技术 1.空间上的复用 多个程序共用一套计算机硬件 多道技术原理 2.时间上的复用 切换+保存状态 1.当一个程序遇到IO操作 操作系统会剥夺该程序的CPU执行权限( 提高了CPU的利用率 ...