Pagini recente » Cod sursa (job #546985) | Diferente pentru utilizator/dornescuvlad intre reviziile 49 si 102 | Profil M@2Te4i | Cod sursa (job #1332445) | Cod sursa (job #2010592)
#include<bits/stdc++.h>
#define Nmax 15001
using namespace std;
ifstream f("datorii.in");
ofstream g("datorii.out");
int n,m,i,op,x,y;
int AIB[Nmax];
void update(int i,int val)
{
while(i<=n)
{
AIB[i]+=val;
i+=(i&(-i));
}
}
int query(int i)
{
int sum=0;
while(i>=1)
{
sum+=AIB[i];
i-=(i&(-i));
}
return sum;
}
int main()
{
f>>n>>m;
for(i=1;i<=n;i++)
{
f>>x;
update(i,x);
}
for(;m;--m)
{
f>>op>>x>>y;
if(!op)
update(x,-y);
else
g<<query(y)-query(x-1)<<'\n';
}
return 0;
}