hdu(1166):敌兵布阵—树状数组的应用

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166

题目意思,就是树状数组的定义几乎一样。

 

值的注意的是,该题目的输入量比较大,第一次采用cin作为输入,TLE了,改用scanf就过了,时间达到了700ms+。

作为练习树状数组的题目吧,熟悉下树状数组。当然这题还可以用线段树来做,但是,代码有点长,还是不太好。

 

代码:

 

//freopen("C:\\Documents and Settings\\All Users\\×ÀÃæ\\in.txt","r",stdin);

#include
#include
#include
#include
#include
#include
#include
#include
#include

using namespace std;

int C[50010];
int n;

int lowbit(int x){return x&-x;}

int sum(int x){
    int ret=0;
    while(x>0){ret+=C[x];x-=lowbit(x);}
    return ret;
}

void add(int x,int d){
    while(x<=n){C[x]+=d;x+=lowbit(x);}
}

int main(){
    //freopen("C:\\Documents and Settings\\All Users\\×ÀÃæ\\in.txt","r",stdin);
    int T;cin>>T;
    for(int cas=1;cas<=T;cas++)
    {
        printf("Case %d:\n",cas);
        memset(C,0,sizeof(C));
        cin>>n;
        for(int i=1;i<=n;i++){
            int t;scanf("%d",&t);
            add(i,t);
        }
        char s[10];
        while(scanf("%s",s)){
            if(s[0]=='E') break;
            int l,r;
            cin>>l>>r;
            if(s[0]=='Q'){
                l=sum(l-1);r=sum(r);
                cout<<(r-l)<


 

 

 

你可能感兴趣的:(树状数组)