Cod sursa(job #2547201)

Utilizator catalingudiu@yahoo.roGudiu Catalin [email protected] Data 15 februarie 2020 09:58:17
Problema Datorii Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.02 kb
#include <bits/stdc++.h>
using namespace std;
ifstream in("datorii.in");
ofstream out("datorii.out");
int ar[400010],n,m;
void up(int st,int dr,int poz,int poza,int val)
{
    if(st>poz||dr<poz)
        return;
    if(st==dr)
    {
        ar[poza]-=val;
        return;
    }
    int mij=(dr+st)/2;
    up(st,mij,poz,poza*2,val);
    up(mij+1,dr,poz,poza*2+1,val);
    ar[poza]=ar[poza*2]+ar[poza*2+1];
}
int fnd(int st,int dr,int poza,int a,int b)
{
    if(st>b||dr<a)
        return 0;
    if(st>=a&&dr<=b)
        return ar[poza];
    int mij=(dr+st)/2;
    int fnd1,fnd2;
    fnd1=fnd(st,mij,poza*2,a,b);
    fnd2=fnd(mij+1,dr,poza*2+1,a,b);
    return fnd1+fnd2;
}
int main()
{
    in>>n>>m;
    for(int i=1;i<=n;i++)
    {
        int val;
        in>>val;
        up(1,n,i,1,-val);
    }
    for(int i=1;i<=m;i++)
    {
        int v,a,b;
        in>>v>>a>>b;
        if(v==0)
            up(1,n,a,1,b);
        if(v==1)
            out<<fnd(1,n,1,a,b)<<'\n';
    }
    return 0;
}