一维树状数组区间更新区间查询

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一维树状数组区间更新区间查询相关的知识,希望对你有一定的参考价值。

推理过程

技术分享

维护两个数组,d[i] = a[i] - a[i - 1],f[i] = i * d[i],剩下的,区间更新和区间查询就和【一维树状数组区间更新单点查询】一样了。

实现源代码

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n = 20;
int a[40], d[40], f[40];

int query(int* arr, int x) {
    int res = 0;
    for(int i = x; i > 0; i -= (i & -i))res += arr[i];
    return res;
}

void update(int* arr, int x, int val) {
    for(int i = x; i <= n; i += (i & -i))arr[i] += val;
}

inline int getsum(int x){
    return (x + 1) * query(d, x) - query(f, x);
}

int main() {
    memset(a, 0, sizeof(a));
    memset(d, 0, sizeof(d));
    memset(f, 0, sizeof(f));
    for(int i = 1; i <= n; ++i) {
        a[i] = i;
        int t = a[i] - a[i - 1];
        update(d, i, t);
        update(f, i, t * i);
    }
    for(int i = 1; i <= n; ++i) {
        printf("sum(%d) = %d\\n", i, getsum(i));
    }
    puts("------------------------------------------");
    int x = 1, y = 10, val = 20;
    update(d, x, val);
    update(d, y + 1, -val);
    update(f, x, val * x);
    update(f, y + 1, -val * (y + 1));
    printf("sum(10) = %d\\n", getsum(10));
    return 0;
}

 

以上是关于一维树状数组区间更新区间查询的主要内容,如果未能解决你的问题,请参考以下文章

二维树状数组

树状数组二维区间加+区间查询模板bzoj3132

树状数组从入门到弃疗

树状数组 P3368区间更新 单点查询

一维树状数组入门

51nod_1199 树的先跟遍历+区间更新树状数组