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

Fenwick Tree(二叉索引树)是一种高级数据结构,用于快速进行区间和查询及元素更新。文章介绍了Fenwick Tree的设计动机,构建与更新方法,以及查询操作,并提供了在LeetCode 307题中的应用示例。

Fenwick Tree也叫做树状数组,或者二叉索引树(BIT,Binary Indexed Tree),由新西兰奥克兰大学的Peter Fenwick博士于1994年提出。Fenwick Tree用数组来表示一棵树(这样空间上更节约),所以它的结点中没有指向左右孩子的指针这样的设计。它可以用于对区间和(range sum)进行快速查询,其元素修改和区间查询的复杂度都是O(\log{n})

 

欢迎关注白马负金羁的博客 http://blog.youkuaiyun.com/baimafujinji,鉴于目前网上盗贴、洗稿等现象严重,为保证公式、图表得以正确显示,强烈建议你从该地址上查看原版博文。本博客主要关注方向包括:数字图像处理、算法设计与分析、数据结构、机器学习、数据挖掘、统计分析方法、自然语言处理。

本博客中,高级数据结构专题已经涵盖的文章包括:

  1. 高级数据结构之Fenwick Tree(Binary Indexed Tree)
  2. 高级数据结构之线段树(Segment Tree)
Fenwick Tree,又称为树状数组(Binary Indexed Tree),是一种基于数组实现的数据结构,用于高效地动态维护前缀和。它可以在O(logn)的时间内完成以下操作:更新某个元素的值,查询某个区间的和。Fenwick Tree的实现原理是将数组分解为一系列的区间和,每个区间和保存在树状数组的相应位置上。通过使用二进制的技巧,可以高效地计算每个区间和。: ``` public class FenWickTree { private int[] values; private int[] bit; public FenWickTree(int length) { values = new int[length]; bit = new int[length + 1]; } public void setValues(int index, int value) { values[index = value; index += 1; while (index < bit.length) { bit[index += value; index += index & -index; } } public int getSum(int index) { int sum = 0; while (index > 0) { sum += bit[index]; index -= index & -index; } return sum; } } ``` 以上代码展示了如何使用Fenwick Tree实现动态维护前缀和的功能。其中setValues()方法用于更新某个元素的值,getSum()方法用于查询某个区间的和。 另外,Fenwick Tree也可以用来解决区间修改的问题。对于元素的修改,我们可以视为区间查询的逆过程,通过从叶节点开始向上更新父节点,依次对每个父节点进行相同的修改操作。具体的实现可以参考下面的示例代码: ``` class FenwickTree { private int[] tree; public FenwickTree(int n) { tree = new int[n + 1]; } public int lowbit(int x) { return x & (-x); } public void add(int i, int val) { while (i < tree.length) { tree[i += val; i += lowbit(i); } } public int query(int i) { int res = 0; while (i > 0) { res += tree[i]; i -= lowbit(i); } return res; } } ``` 这段代码展示了如何使用Fenwick Tree解决区间修改的问题。add()方法用于修改某个元素,query()方法用于查询某个区间的和。 综上所述,Fenwick Tree是一种用于高效地动态维护前缀和的数据结构,可以在O(logn)的时间内完成更新和查询操作。同时,它也可以应用于区间修改的问题。 #### 引用[.reference_title] - *1* *3* [【数据结构与算法】树状数组](https://blog.youkuaiyun.com/zzy_NIC/article/details/130616434)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [6.10 Fenwick树](https://blog.youkuaiyun.com/m0_66201040/article/details/122923027)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

白马负金羁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值