首页 > 编程语言 > 详细

树状数组模板

时间:2018-10-27 21:38:28      阅读:197      评论:0      收藏:0      [点我收藏+]

 HDU 1166(敌兵布阵)(树状数组 单点更新区间求和)

技术分享图片
#include<iostream>
#include<cstring>
#include<cmath>
using namespace std;
#define lowbit(x) x & (-x)//lowbit函数
#define LL long long  
LL a[100005],n;
void updata(LL x,LL v) {//更新函数
    while(x<=n) {
        a[x]+=v;
        x+=lowbit(x);
    }
}
LL query(LL x) {//查询函数
    LL sum=0;
    while(x) {
        sum+=a[x];
        x-=lowbit(x);
    }
    return sum;
}
int main() {
    LL t;
    cin>>t;
    LL d=1;
    while(t--) {
        cout<<"Case "<<d<<":"<<endl;
        cin>>n;
        LL s;
        memset(a,0,sizeof(a));
        for(LL i=1; i<=n; i++) {
            cin>>s;
            updata(i,s);
        }
        string ss;
        int l,r;
        while(cin>>ss)
        {
            if(ss=="End"){
                break;
            } 
            cin>>l>>r;
            if(ss[0]==A) {
                updata(l,r);
            } else if(ss[0]==S) {
                updata(l,-r);
            } else {
                cout<<query(r)-query(l-1)<<endl;
            }
        }
        d+=1;
    }
    return 0;
}
View Code

 

树状数组模板

原文:https://www.cnblogs.com/hwy499/p/9863505.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!