Cod sursa(job #1974282)

Utilizator usureluflorianUsurelu Florian-Robert usureluflorian Data 27 aprilie 2017 12:08:38
Problema Datorii Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.58 kb
#include <fstream> //aplicatie aib
using namespace std;
ifstream f ("datorii.in");
ofstream g ("datorii.out");
int a[15001],m,n,x,i,y,t;
void adun()
{
     for(int p=i;p<=n;p+=((p^(p-1))&p)) a[p]+=x;
}
void scad()
{
    for(int p=y;p<=n;p+=((p^(p-1))&p)) a[p]-=x;
}
int solve(int st)
{
    int s=0;
    for(int p=st;p>0;p-=((p^(p-1))&p)) s+=a[p];
    return s;
}
int main()
{
    f>>n>>m;
    for(i=1;i<=n;++i) {f>>x;adun();}
    for(i=1;i<=m;++i)
    {
        f>>t>>y>>x;
        if(t==0) scad();
        else g<<(solve(x)-solve(y-1))<<'\n';
    }
    return 0;
}