树状数组
2020-12-13 14:10
阅读:319
标签:printf onclick 区间 i++ eve class const 查询 none
#include#include using namespace std; const int maxn=5e5+10; long long a[maxn],c[maxn]; inline int lowbit(int x) { return x&(-x); } void build(int n) { for(int i=1;i) { for(int j=i;jlowbit(j)) c[j]+=a[i]; } return ; } void update(int x,int k,int n) { for(;xk; } long long query(int x) { long long ans=0; while(x) { ans+=c[x]; x-=lowbit(x); } return ans; } int main() { int n,m; scanf("%d %d",&n,&m); for(int i=1;i) { scanf("%lld",&a[i]); } build(n); int op,x,y; while(m--) { scanf("%d %d %d",&op,&x,&y); if(op==1) { update(x,y,n); } else { if(x>y) swap(x,y); printf("%lld\n",query(y)-query(x-1)); } } return 0; }
#include#include using namespace std; const int maxn=5e5+10; long long a[maxn],c[maxn],b[maxn]; inline int lowbit(int x) { return x&(-x); } void build(int n) { for(int i=1;i) { for(int j=i;jlowbit(j)) c[j]+=a[i]; } return ; } void update(int x,int k,int n) { for(;xk; } long long query(int x) { long long ans=0; while(x) { ans+=c[x]; x-=lowbit(x); } return ans; } int main() { int n,m; scanf("%d %d",&n,&m); for(int i=1;i) { scanf("%lld",&b[i]); a[i]=b[i]-b[i-1]; } build(n); int op,x,y,k; while(m--) { scanf("%d %d",&op,&x); if(op==1) { scanf("%d %d",&y,&k); update(x,k,n); update(y+1,-k,n); } else { printf("%lld\n",query(x)); } } return 0; }
树状数组
标签:printf onclick 区间 i++ eve class const 查询 none
原文地址:https://www.cnblogs.com/wyhbadly/p/11552440.html
上一篇:c#如何写服务,打包和卸载服务
下一篇:C# 如何寫入cookie
评论
亲,登录后才可以留言!