#include<string.h>
#include<stdio.h>
#define lowbit(x) (x&(-x))//计算a^k,这是做神奇的地方
const int N = 50005;
int a[N], n;
void Add(int x, int y)//将每个结点的值都加上,当然也可以修改某个结点的值
{
while(x <= n)
{
a[x] += y;
x += lowbit(x);//跳到下一个结点
}
}
int Sum(int m)//计算前m项和
{
int ans = 0;
while(m > 0)
{
ans += a[m];
m -= lowbit(m);//返回上一个结点
}
return ans;
}
int main()
{
int t, Case = 0;
scanf("%d",&t);
while(t-- && scanf("%d",&n))
{
int b;
char s[10];
memset(a,0,sizeof(a));
for(int i = 1; i <= n; i++)
{
scanf("%d",&b);
Add(i,b);
}
printf("Case %d:\n",++Case);
while(scanf("%s",s) && s[0]!='E')
{
int x, y;
scanf("%d%d",&x,&y);
if(s[0] == 'Q')
printf("%d\n",Sum(y)-Sum(x-1));
if(s[0] == 'A')
Add(x,y);
if(s[0] == 'S')
Add(x,-y);
}
}
return 0;
}
HDU 1166 树状数组
最新推荐文章于 2019-06-29 12:27:16 发布