题意:题意非常清楚;

策略;如题。

这道题就是简单的线段树应用,据说还能够用树状数组来做,等我学了之后在说吧。

代码:

#include<stdio.h>
#include<string.h>
#define LC l, m, rt<<1
#define RC m+1, r, rt<<1|1
#define LL long long
#define MAXN 1000000
LL sum[MAXN<<2];
void PushUp(int rt)
{
sum[rt] = sum[rt<<1]+sum[rt<<1|1];
}
void creat(int l, int r, int rt)
{
if(l == r){
scanf("%lld", &sum[rt]);
return;
}
int m = (l+r)>>1;
creat(LC);
creat(RC);
PushUp(rt);
}
void update(int p, int num, int l, int r, int rt)
{
if(l == r){
sum[rt] += (LL)num;
return;
}
int m = (l+r)>>1;
if(p <= m) update(p, num, LC);
else update(p, num, RC);
PushUp(rt);
}
LL query(int ll, int rr, int l, int r, int rt)
{
if(ll <= l&&r<= rr){
return sum[rt];
}
LL res = 0;
int m = (l+r)>>1;
if(ll <= m) res += query(ll, rr, LC);
if(rr > m) res += query(ll, rr, RC);
return res;
}
int main()
{
int n, m;
scanf("%d%d", &n, &m);
creat(1, n, 1);
char s[10];
int a, b;
while(m -- ){
scanf("%s", s);
if(s[0] == 'Q'){
scanf("%d%d", &a, &b);
printf("%lld\n", query(a, b, 1, n, 1));
}
else{
scanf("%d%d", &a, &b);
update(a, b, 1, n, 1);
}
}
return 0;
}

题目链接:http://acm.nyist.net/JudgeOnline/problem.php?

pid=116

最新文章

  1. HTML5- Canvas入门(五)
  2. makefile示例
  3. .htaccess 的写法
  4. tomcat下部署可以访问的文件夹
  5. mysql中常用的公式及个人演示
  6. NYOJ 536 开心的mdd【矩阵链乘】
  7. Caesar cipher
  8. Spring管理Hibernate
  9. web服务器配置方法
  10. MySQL+heartbeat+nfs做高可用
  11. Linux的学习笔记_Day1
  12. 利用ATiny85制作BadUSB
  13. 动态规划——Russian Doll Envelopes
  14. 从零学习Fluter(五):Flutter中手势滑动拖动已经网络请求
  15. js原型链的深度理解!
  16. 如何在 Linux 服务器上部署多个 Tomcat
  17. HTML5 canvas getImageData() 方法
  18. 【Codeforces 696D】Legen...
  19. Flink &ndash; WindowedStream
  20. excel工作表密码破解方法

热门文章

  1. POJ #1025 Department
  2. HDU——2093考试排名(string类及其函数的运用以及istringstream)
  3. HDU-1528/1962 Card Game Cheater
  4. PHP中的验证码类(完善验证码)
  5. vue.js源码学习分享(八)
  6. 标准C程序设计七---102
  7. 转载——Step by Step 创建一个 Web Service
  8. LaTeX 如何在文档的侧面插入图片实现&quot;绕排&quot;?
  9. 一些yuv视频下载地址
  10. Java中获取ServletContext的方法