Fenwick Tree / Binary Indexed Tree (树状数组)的学习

Posted johnnyzhao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Fenwick Tree / Binary Indexed Tree (树状数组)的学习相关的知识,希望对你有一定的参考价值。

Binary Indexed Tree的作用

Binary Indexed Tree(BIT)现多用于高效计算数列的前序和,区间和。它可以在O(logn)的时间得到任意的前序和(prefix sum)。如一个array[2,5,-1,3,6],要计算第2个元素到第4个元素的和:5+-1+3=7。

BIT通过保存部分的sum到各个节点中,然后通过遍历,从树的叶子到根来得到total sum。

大神的视频

以上是关于Fenwick Tree / Binary Indexed Tree (树状数组)的学习的主要内容,如果未能解决你的问题,请参考以下文章

高级数据结构之Fenwick Tree(Binary Indexed Tree)

[Leetcode] Binary Index Tree

树状数组(fenwick tree)

POJ 3321 Apple Tree DFS序+fenwick

算法笔记 - 树状数组 (Fenwick tree)

Binary Tree和Binary Search Tree