Tido 习题-二叉树-树状数组实现
Posted tidoblogs
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Tido 习题-二叉树-树状数组实现相关的知识,希望对你有一定的参考价值。
题目描述
这就是一个简单的树状数组入门题
可以动态地进行区间和查询
随时可能会进行更新
#include<iostream> #include<cstdio> #include<algorithm> #include<cmath> #include<string> #include<cstring> using namespace std; int C[100005]; int n,m; int lowbit(int x){ return x&(-x); } void add(int x,int d){ while(x<=n){ C[x]+=d; x+=lowbit(x); }//修改是从左往右 } int sum(int x){ int ret=0; while(x>0){ ret+=C[x]; x-=lowbit(x);//求和是从右往左 } return ret; } int main() { cin>>n>>m; for(int i=1;i<=n;i++) { int x; cin>>x; add(i,x); } for(int i=1;i<=m;i++){ int k,a,b; cin>>k>>a>>b; if(k==1) add(a,b); if(k==0) cout<<sum(b)-sum(a-1)<<endl; } return 0; }
如果对树状数组的一些基础知识还不太了解
可以先看一下https://www.cnblogs.com/Tidoblogs/p/10887644.html
以上是关于Tido 习题-二叉树-树状数组实现的主要内容,如果未能解决你的问题,请参考以下文章
NC41 最长无重复子数组/NC133链表的奇偶重排/NC116把数字翻译成字符串/NC135 股票交易的最大收益/NC126换钱的最少货币数/NC45实现二叉树先序,中序和后序遍历(递归)(代码片段