hdu1556 树状数组区间更新单点查询板子

就是裸的区间更新:

相对于直观的线段树的区间更新,树状数组的区间更新原理不太相同:由于数组中的一个结点控制的是一块区间,当遇到更新【l,r】时,先将所有能控制到 l 的结点给更新了,这样一来就是一下子更新到【l,+无穷】了,所以需要将【r+1,+无穷】区间的更新消去,那么同理,【r+1,+无穷】反向减掉相同的数即可

#include<bits/stdc++.h>
using namespace std;
#define maxn 100005
int bit[maxn],a,b,n;
void add(int x,int num){
for(int i=x;i<=;i+=i&-i)
bit[i]+=num;
}
int query(int x){
int res=;
for(int i=x;i;i-=i&-i)
res+=bit[i];
return res;
}
int main(){
while(scanf("%d",&n),n){
memset(bit,,sizeof bit);
for(int i=;i<=n;i++){
scanf("%d%d",&a,&b);
add(a,);add(b+,-);
}
for(int i=;i<n;i++)
printf("%d ",query(i));
printf("%d\n",query(n));
}
}
上一篇:【转】一个从32位机器移植到64位机器时的c问题


下一篇:做一款直播类app