Cod sursa(job #1694716)

Utilizator alittlezzCazaciuc Valentin alittlezz Data 25 aprilie 2016 21:00:58
Problema Datorii Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.87 kb
#include <stdio.h>
#include <algorithm>
#include <math.h>

using namespace std;

#define ll long long unsigned
#define pb push_back
#define X first
#define Y second;

int aib[15005],n;

void update(int poz, int x){
    for(;poz <= n;poz += poz&(-poz)){
        aib[poz] += x;
    }
}

int query(int poz){
    int res = 0;
    for(;poz;poz -= poz&(-poz)){
        res += aib[poz];
    }
    return res;
}

int main()
{
    freopen("datorii.in", "r", stdin);
    freopen("datorii.out", "w", stdout);
    int q,x,i;
    scanf("%d %d",&n,&q);
    for(i = 1;i <= n;i++){
        scanf("%d",&x);
        update(i, x);
    }
    int op,z,v;
    for(i = 1;i <= q;i++){
        scanf("%d %d %d",&op,&z,&v);
        if(op == 0){
            update(z, -v);
        }else{
            printf("%d\n",query(v)-query(z-1));
        }
    }
    return 0;
}