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 题目: 思路: 这种题目当初卡了我很久,今天早训时遇到一个一样得题,一眼就想到用栈模拟,就又回来把这 ...
随机推荐
- 【MySQL】服务无法启动(Mac)
如图所示: 点击 Start MySQL Server 没反应-- 终端输入 mysql 命令时报错如下: ERROR 2002 (HY000): Can't connect to local MyS ...
- 浅析scrapy与scrapy_redis区别
最近在工作中写了很多 scrapy_redis 分布式爬虫,但是回想 scrapy 与 scrapy_redis 两者区别的时候,竟然,思维只是局限在了应用方面,于是乎,搜索了很多相关文章介绍,这才搞 ...
- oracle的JDBC连接
package com.xian.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.Pr ...
- Thinkphp5.0快速入门笔记(2)
学习来源与说明 https://www.kancloud.cn/thinkphp/thinkphp5_quickstart 测试与部署均在windows10下进行学习. 示例建立新的模块和控制器 在a ...
- 当下最流行的微服务与spring cloud,你搞清楚了吗?
微服务架构:Spring-Cloud 什么是微服务? 微服务就是把原本臃肿的一个项目的所有模块拆分开来并做到互相没有关联,甚至可以不使用同一个数据库. 比 如:项目里面有User模块和Power模块, ...
- 二叉查找树(查找、插入、删除)——C语言
二叉查找树 二叉查找树(BST:Binary Search Tree)是一种特殊的二叉树,它改善了二叉树节点查找的效率.二叉查找树有以下性质: (1)若左子树不空,则左子树上所有节点的值均小于它的根节 ...
- 0R电阻在PCB布线中对布线畅通的一个小妙用
在PCB布线中,我们都会尽量节约板子空间,将元器件排布的紧密一些,难免会遇到布线不通的时候. 博主下面就来说一个关于0R电阻在PCB布线使之畅通的一个小妙用. 使用0R电阻前 假设我们这个TXD的线周 ...
- 消息中间件-activemq入门(二)
上一节我们了解了JMS规范并且知道了JMS规范的良好实现者-activemq.今天我们就去了解一下activemq的使用.另外我们应该抱着目的去学习,别忘了我们为什么要使用消息中间件:解耦系统之间的联 ...
- 基于SpringBoot从零构建博客网站 - 分页显示文章列表功能
显示文章列表一般都是采用分页显示,比如每页10篇文章显示.这样就不用每次就将所有的文章查询出来,而且当文章数量特别多的时候,如果一次性查询出来很容易出现OOM异常. 后台的分页插件采用的是mybati ...
- 使用文本框TextView/EditText的开源库清单
在实际的开发中TextView和EditText是非常基本的控件.这两个控件的使用也是十分简单.而TextView/EditText的功能其实也是非常强大,例如简单的图文就可以使用TextView配合 ...