Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 42514 Accepted Submission(s): 17988
线段树模板题
用cin交的时候超时了
以后干脆全stdio好了
#include <stdio.h> #include <string.h> const int maxn=50005; struct node { int l; int r; int n; void init(int a,int b,int c) { l=a; r=b; n=c; } }T[3*maxn]; void build(int l,int r,int k) { if(l==r) { T[k].init(l,r,0); return; } int mid = (l+r)/2; T[k].init(l,r,0); build(l,mid,2*k); build(mid+1,r,2*k+1); } void update(int l,int n,int k) { if(T[k].l==T[k].r&&T[k].l==l) { T[k].n+=n; return; } int mid = (T[k].l+T[k].r)/2; if(l<=mid) update(l,n,2*k); else update(l,n,2*k+1); T[k].n=T[2*k].n+T[2*k+1].n; } int ans; void Query(int l,int r,int k) { if(T[k].l==l&&T[k].r==r) { ans+=T[k].n; return; } int mid = (T[k].l+T[k].r)/2; if(mid>=r) Query(l,r,2*k); else if(mid<l) Query(l,r,2*k+1); else { Query(l,mid,2*k); Query(mid+1,r,2*k+1); } } int main() { int t,n; scanf("%d",&t); for(int kase=1;kase<=t;kase++) { scanf("%d",&n); build(1,n,1); for(int i=1;i<=n;i++) { int temp; scanf("%d",&temp); update(i,temp,1); } printf("Case %d:\n",kase); char s[11]; while(scanf("%s",s)) { if(strcmp(s,"End")==0) break; int a,b; scanf("%d%d",&a,&b);; if(strcmp(s,"Add")==0) update(a,b,1); else if(strcmp(s,"Sub")==0) update(a,-b,1); else { ans=0; Query(a,b,1); printf("%d\n",ans); } } } return 0; }
原文:http://www.cnblogs.com/Run-dream/p/3885032.html