似乎当初就是学到这里然后自己就去乱搞了?然后就弃坑了?想想挺难受的其实
树状数组板子题。初始化wa了一发
1 #include2 #include 3 #include 4 #include 5 #include 6 #include 7 #include 8 using namespace std; 9 #define mem(a,b) memset(a,b,sizeof(a))10 #define ll long long11 #define inf 100000000012 #define maxn 4000013 #define eps 1e-1214 #define mod 100000000715 inline int read()16 {17 int x=0,f=1;char ch=getchar();18 while(ch<'0'||ch>'9') { if(ch=='-') f=-1;ch=getchar();}19 while(ch>='0'&&ch<='9') {x=10*x+ch-'0';ch=getchar();}20 return x*f;21 }22 int a[50005],n;23 char s[20];24 int lowbit(int i)25 {26 return i&(-i);27 }28 void update(int i,int peo)29 {30 while(i<=n)31 {32 a[i]+=peo;i+=lowbit(i);33 }34 }35 int sum(int i)36 {37 int sum=0;38 while(i>0)39 {40 sum+=a[i];41 i-=lowbit(i);42 }43 return sum;44 }45 int main()46 {47 int T;48 T=read();49 int num=1,peo;50 while(T--)51 {52 n=read();53 mem(a,0);54 for(int i=1;i<=n;++i) peo=read(),update(i,peo);55 printf("Case %d:\n",num++);56 while(scanf("%s",s))57 {58 if(s[0]=='E') break;59 int x,y;60 x=read();y=read();61 if(s[0]=='Q') printf("%d\n",sum(y)-sum(x-1));62 else if(s[0]=='A') update(x,y);63 else update(x,-y);64 }65 }66 return 0;67 }