树状数组初始化

《高级数据结构》 

大多数情况下A数组一开始不全是0,如何初始化树状数组呢?一种显而易见的方法就是将A中的元素一个一个地添加进树状数组,不过这样的预处理时间复杂度为O(logn)。下面的算法更加优美,因为我们已经知道树状数组中:sum[index] = a[index-C(index)+1]+...+a[index],所以只需要一开始再维护一个前缀和的数组pre[x] = a[1]+a[2]+...+a[x],这样sum数组就可以如下初始化了:sum[index] = pre[i]-pre[index-C(index)]。特别地,如果A数组一开始全是1,那么sum[index]的值就是C(index)。
C(index) = index&(-index);
#include <iostream>
#include<cstdio>
#include<cstring>
#include <cmath>
#include <queue>
#include <stack>
#include <algorithm>
#include <cmath>
#include <vector>
#define LL long long
#define MAXN 100000
#define inf 0x3f3f3f3f
using namespace std;
int pre[MAXN];
int sum[MAXN];
int n;
int a[MAXN];
int lowbit(int index){
    return index&(-index);
}
void init(){
    for(int i = 1; i <= n; ++i){
        sum[i] = pre[i]-pre[i-lowbit(i)];
    }
}
int query(int k){
    int ans = 0;
    while(k > 0){
        ans += sum[k];
        k -= lowbit(k);
    }
    return ans;
}
int main()
{
    scanf("%d",&n);
    pre[0] = 0;
    for(int i = 1; i <= n; ++i){
        scanf("%d",&a[i]);
        pre[i] = a[i]+pre[i-1];
    }
    init();
    int a,b;
    while(~scanf("%d%d",&a,&b)){
        int ans = query(b)-query(a-1);
        printf("%d\n",ans);
    }
    return 0;
}


  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值