Cod sursa(job #1255476)

Utilizator AlexbiraianuBiraianu Alex Valentin Alexbiraianu Data 4 noiembrie 2014 20:23:42
Problema Datorii Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.58 kb
#include<fstream>
#include<iostream>
#define ub(x) (x&(-x))
using namespace std;
ifstream f("datorii.in");
ofstream g("datorii.out");
int aib[15001];
int n;
void add(int x,int y){
    int i;
    for(i=x;i<=n;i+=ub(i))
        aib[i]+=y;
}
int sum(int x){
    int i,s=0;
    for(i=x;i>0;i-=ub(i))
        s+=aib[i];
    return s;
}
int main(){
    int m,i,p,x,y;
    f>>n>>m;
    for(i=1;i<=n;i++){
        f>>x;
        add(i,x);
    }
    for(i=1;i<=m;i++){
        f>>p>>x>>y;
        if (p==0) add(x,-y);
        else g<<sum(y)-sum(x-1);
    }
    return 0;
}