【模板】3 树状数组1(单点修改区间查询)

【模板】3 树状数组1(单点修改区间查询),第1张

概述    #include<iostream> #include<cstdio>using namespace std; int pd,c[500001],a[500001],x,y,k,n,m; int lowbit(int xx) { return xx&-xx; } void update(int xx,int yy) { while(xx<=n) { c[xx]+=yy; xx+=low

 

 

#include<iostream> #include<cstdio>using namespace std; int pd,c[500001],a[500001],x,y,k,n,m; int lowbit(int xx) { return xx&-xx; } voID update(int xx,int yy) { while(xx<=n) { c[xx]+=yy; xx+=lowbit(xx); } } int getsum(int xx) { int sum=0; while(xx>0) { sum+=c[xx]; xx-=lowbit(xx); } return sum; } int main() { cin>>n>>m; for(int i=1;i<=n;i++) { cin>>a[i]; update(i,a[i]); } for(int i=1;i<=m;i++) { cin>>pd; if(pd==1) { cin>>x>>k; update(x,k); } if(pd==2) { cin>>x>>y; cout<<getsum(y)-getsum(x-1)<<endl; } } return 0; }

 

                     2019-09-09 By十四日的夏
总结

以上是内存溢出为你收集整理的【模板】3 树状数组1(单点修改区间查询)全部内容,希望文章能够帮你解决【模板】3 树状数组1(单点修改区间查询)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1015726.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存