C++树状数组

 

#include <iostream>
#include <cstring>

using namespace std;

int lowbit(int n) {
    return n - (n & (n - 1));
}
/**
 *
原始数组的i位置增加v后,更新c数组
 */
void update(int n, int i, int v, int c[]) {
    for (int k = i; k <= n; k += lowbit(k)) {
        c[k] += v;
    }
}

int getSum(int c[], int i) {
    int sum = 0;
    for (int k = i; k >= 1; k -= lowbit(k)) {
        sum += c[k];
    }
    return sum;
}

int main() {
    int arr[] = {1, 2, 3, 4, 5, 6, 7, 8};
    int c[9];
    memset(c, 0, sizeof(c));
    for (int i = 0; i < 8; ++i) {
        update(9, i + 1, arr[i], c);
    }
    cout << getSum(c, 5) << endl;
    cout << getSum(c, 6) << endl;
    cout << getSum(c, 7) - getSum(c, 4) << endl;

    return 0;
}

posted @ 2020-07-08 18:29  HDAWN  阅读(141)  评论(0编辑  收藏  举报