2019暑训 Day6 树状数组、倍增、分治

Day6

今天才补博客…我认错…

树状数组

树状数组是顺序数组中抽象出的一个树形数据结构,可以方便而高效地完成某些区间查询、修改的一系列的问题。相比于线段树,树状数组的实现比较容易,比较适用于某些不太复杂但是也有一定的效率要求的问题上。

在树状数组BIT的构造、应用上,有一些前置知识点:

  1. lowbit(x) = x & (-x)

在这里插入图片描述
2. c[n] = sum[n] - sum(n - lowbit(n)),其项数即为lowbit(n)
3. father[x] = x + lowbit(x)
4. 据此,我们得到BIT的单点修改和求前缀和的办法:在这里插入图片描述
5. 此外,我们比较一下不同的数据结构的效率:*-

我们考虑三个BIT的典型例题:
一、单点修改、区间查询: 如上所述

二、区间修改、单点查询:只需要构造差分数组,就可以将原问题转化为差分数组的双点修改(注意两个边界的处理,左边修

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值