Pagini recente » Cod sursa (job #1007783) | Cod sursa (job #2271474) | Cod sursa (job #578907) | Cod sursa (job #2790370) | Cod sursa (job #3244171)
#include <fstream>
using namespace std;
int a[1000002];
int v[1000002];
int p,q,t,x;
int m,n,c;
int s, s2;
int calc(int i)
{
int sum=0;
while(i>0)
{
sum+=v[i];
i-=i&-i;
}
return sum;
}
void update(int i,int val)
{
while(i<=n)
{
v[i]+=val;
i+=i&-i;
}
}
int main()
{
ifstream cin("datorii.in");
ofstream cout("datorii.out");
cin>>n>>m;
for(int i=1;i<=n;i++)
{
cin>>a[i];
update(i,a[i]);
}
for(int i=0;i<m;i++)
{
cin>>c;
if(c==0)
{
cin>>t>>x;
update(t,-x);
}
else if(c==1)
{
cin>>p>>q;
s2=calc(q);
s=calc(p-1);
cout<<s2-s<<'\n';
}
}
return 0;
}