Cod sursa(job #2284561)

Utilizator DavidDragulinDragulin David DavidDragulin Data 17 noiembrie 2018 11:35:01
Problema Datorii Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.63 kb
#include <bits/stdc++.h>

using namespace std;
ifstream fin("datorii.in");
ofstream fout("datorii.out");
int n,m,x,y,i,j,aib[15009],v[15009],c;
void update(int i,int x)
{
    for (int j=i;j<=n;j+=j^(j&(j-1)))
        aib[j]+=x;
}
int query(int i)
{
    int s=0;
    for(int j=i;j>=1;j-=j^(j&(j-1)))
        s+=aib[j];
    return s;
}
int main()
{
    fin>>n>>m;
    for(i=1;i<=n;i++)
    {
        fin>>v[i];
        update(i,v[i]);
    }
    for(i=1;i<=m;i++)
    {
        fin>>c>>x>>y;
        if(c==0)
            update(x,-y);
        else
            fout<<query(y)-query(x-1)<<'\n';
    }
    return 0;
}