树状数组模板

// 单点更新区间求和  树状数组 
#include<bits/stdc++.h>
using namespace std;
#define ll long long
int n,c[1000010];
int lowbit(int x){
    return x&(-x);
}
void Add(int x,ll d){
    while(x<=n){
        c[x]+=d;
        x+=lowbit(x);
    }
}
ll sum(int x){
    ll ret=0;
    while(x>=1){
        ret+=c[x];
        x-=lowbit(x);
    }
    return ret;
}
int main(){//数组有n个数 m次操作 
    int i,m;
    scanf("%d%d",&n,&m);
    for(i=1;i<=n;i++){
        ll x;
        scanf("%lld",&x);
        Add(i,x);
    }
    while(m--){
        int num;
        scanf("%d",&num);
        if(num==1){// 第x个数增加k 
            int x;ll k;
            scanf("%d%lld",&x,&k);
            Add(x,k);
        }else{
            int x,y;//求区间x-y的和 
            scanf("%d%d",&x,&y);
            printf("%lld\n",sum(y)-sum(x-1));
        }
    }
    return 0;
}

 

全部评论

相关推荐

01-14 12:08
门头沟学院 Java
神哥了不得:(非引流)1.既然发出来了简历,就稍微提一点点小建议,确实简历很不错了,练手项目可以换一些质量高的,工作内容,可以加上一些量化指标,比如第一条系统响应速度由多少变成多少,减少了百分之多少,第4条就很不错。2.广投,年前实习招募比较少了
点赞 评论 收藏
分享
02-05 08:49
已编辑
武汉大学 Web前端
野猪不是猪🐗:36k和36k之间亦有差距,ms的36k和pdd的36k不是一个概念
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务