随笔-68  评论-10  文章-0  trackbacks-0
链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166
#include "iostream"
#include 
"cstring"
using namespace std;
struct segment_tree
{
    
int left,right,num;
}
tree[150010];

int a[50010];
int T,n;

void Build(int left,int right,int i)
{
    tree[i].left
=left;
    tree[i].right
=right;
    
if(left==right)
    
{
        tree[i].num
=a[left];
        
return;
    }

    
int mid=(left+right)/2;
    Build(left,mid,
2*i);
    Build(mid
+1,right,2*i+1);
    tree[i].num
=tree[2*i].num+tree[2*i+1].num;
}


void Updata(int id,int num,int i)
{
    
if(tree[i].left==tree[i].right)
    
{
        tree[i].num
+=num;
        
return;
    }

    
else
    
{
        tree[i].num
+=num;
        
if(id<=tree[i*2].right) Updata(id,num,i*2);
        
else Updata(id,num,i*2+1);
    }

}


int Query(int left,int right,int i)
{
    
if(tree[i].left==left&&tree[i].right==right) return tree[i].num;
    
int mid=(tree[i].left+tree[i].right)/2;
    
if(right<=mid) return Query(left,right,i*2);
    
else if(left>mid) return Query(left,right,i*2+1);
    
else return Query(left,mid,i*2)+Query(mid+1,right,i*2+1);
}


int main()
{
    
int i,t1,t2;
    
char s[10];
    scanf(
"%d",&T);
    
for(int k=1;k<=T;k++)
    
{
        scanf(
"%d",&n);
        
for(i=1;i<=n;i++) scanf("%d",&a[i]);
         Build(
1,n,1);
        printf(
"Case %d:\n",k);
        
while(1)
        
{
            scanf(
"%s",s);
            
if(strcmp(s,"End")==0break;
            scanf(
"%d%d",&t1,&t2);
            
if(strcmp(s,"Query")==0)
            
{
                
int ans=Query(t1,t2,1);
                printf(
"%d\n",ans);
            }

            
if(strcmp(s,"Sub")==0) Updata(t1,-t2,1);
            
if(strcmp(s,"Add")==0) Updata(t1,t2,1);
        }

    }

    
return 0;
}
posted on 2010-11-14 12:45 wuxu 阅读(286) 评论(0)  编辑 收藏 引用 所属分类: 数据结构

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理