参考自http://www.notonlysuccess.com/index.php/segment-tree-complete/

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
using namespace std;
const int maxn=111111;
long long sum[maxn<<2];
long long col[maxn<<2];
void pushUp(int rt)
{
sum[rt]=sum[rt<<1]+sum[rt<<1|1];
}
void pushDown(int rt,int m)
{
if(col[rt])
{
col[rt<<1]+=col[rt];
col[rt<<1|1]+=col[rt];
sum[rt<<1]+=col[rt]*(m-(m>>1));
sum[rt<<1|1]+=col[rt]*(m>>1);
col[rt]=0;
}
}
void build(int l,int r,int rt)
{
col[rt]=0;
if(r==l)
{
scanf("%lld",&sum[rt]);
return ;
}
int m=(r+l)>>1;
build(lson);
build(rson);
pushUp(rt);
}
void update(int L,int R,int d,int l,int r,int rt)
{
if(L<=l&&r<=R)
{
sum[rt]+=d*(r-l+1);
col[rt]+=d;
return;
}
pushDown(rt,r-l+1);
int m=(l+r)>>1;
if(L<=m) update(L,R,d,lson);
if(m<R) update(L,R,d,rson);
pushUp(rt);
}
long long query(int L,int R,int l,int r,int rt)
{
long long ret=0;
if(L<=l&&r<=R)
{
return sum[rt];
}
pushDown(rt,r-l+1);
int m=(r+l)>>1;
if(L<=m) ret+=query(L,R,lson);
if(m<R) ret+=query(L,R,rson);
return ret;
}
int main()
{
int n,m;
while(scanf("%d%d",&n,&m)!=EOF)
{
build(1,n,1);
char c;
long long a,b,d;
for(int i=0;i<m;i++)
{
getchar();
scanf("%c%lld%lld",&c,&a,&b);
if(c=='Q')
printf("%lld\n",query(a,b,1,n,1));
else
{
scanf("%lld",&d);
update(a,b,d,1,n,1);
}
}
}
return 0;
}

最新文章

  1. nginx负载均衡集群
  2. 针对Asp.net MVC SEO的几点建议
  3. 如何判断两个String是否是Anagrams_java实现
  4. 关于childNodes的length的问题
  5. 10+优秀“分步引导”jQuery插件(转)
  6. uva 12549 最大流
  7. 数学语言和程序语言的对比:面向过程与面向集合&amp;命题
  8. Android注解支持(Support Annotations)
  9. IP 转地址
  10. WSAEventSelect
  11. CF卡是什么
  12. 让Sqlite脱离VC++ Runtime独立执行
  13. [Q]“获取AutoCAD安装信息时失败...”解决方法
  14. ASP.NET 运行机制详解
  15. 如何编写更好的SQL查询:终极指南-第一部分
  16. SqlBulkCopy效率低下原因分析
  17. 利用拷贝data目录文件的方式迁移mysql数据库
  18. iOS xcode9 framework静态库的创建以及xib和图片的使用记录
  19. 2018-2019 20165232 Exp5 MSF基础应用
  20. Java 学习札记(二)TomCat安装配置

热门文章

  1. 51 nod 1693 水群
  2. magento megatron主题加入中文
  3. keras安装及使用
  4. apiCloud实现加载更多效果,基本完美~
  5. zzulioj--1716--毒(模拟水题)
  6. 1. Git-2.12.0-64-bit .exe下载
  7. 相辅相成的求最单源短路径算法:(SPFA&amp; dijkstra)
  8. SAS拆分数据集
  9. (转载)10个实用的但偏执的Java编程技术
  10. 【原创】Apache和Tomcat实现动静分离