Cod sursa(job #3140639)

Utilizator Samoila_AlexandruSamoilaAlexandru Samoila_Alexandru Data 8 iulie 2023 00:33:41
Problema Datorii Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.76 kb
#include <fstream>

using namespace std;

ifstream fin("datorii.in");
ofstream fout("datorii.out");

const int nMax=15e3+5;

int n, m, op, p, q, aib[nMax];

void update(int p, int val)
{
    for(int i=p; i<=n; i+=(i&-i))
        aib[i]+=val;
}

int query(int p)
{
    int s=0;
    for(int i=p; i; i-=(i&-i))
        s+=aib[i];
    return s;
}

int main()
{
    ios_base::sync_with_stdio(false);
    fin.tie(0);

    fin>>n>>m;
    int x;
    for(int i=1; i<=n; i++)
    {
        fin>>x;
        update(i, x);
    }

    for(int i=0; i<m; i++)
    {
        fin>>op>>p>>q;
        if(op==0)
            update(p, -q);
        else fout<<query(q) - query(p-1)<<'\n';
    }

    fin.close();
    fout.close();

    return 0;
}