Pagini recente » Cod sursa (job #333857) | Cod sursa (job #2016505) | Monitorul de evaluare | Cod sursa (job #2476587) | Cod sursa (job #2013765)
#include<fstream>
using namespace std;
ifstream fi("datorii.in");
ofstream fo("datorii.out");
int F[15001],n,m,i,x,tip,p,q;
void update(int poz, int val)
{
while(poz<=n)
{
F[poz]+=val;
poz=poz+(poz&(poz^(poz-1)));
}
}
int f(int poz)
{
int rez=0;
while(poz>0)
{
rez+=F[poz];
poz=poz-(poz&(poz^(poz-1)));
}
return rez;
}
int query(int st, int dr)
{
return f(dr)-f(st-1);
}
int main()
{
fi>>n>>m;
for(i=1; i<=n; i++)
{
fi>>x;
update(i,x);
}
for(i=1; i<=m; i++)
{
fi>>tip>>p>>q;
if(tip==0)
{
update(p,-q);
}
else
{
fo<<query(p,q)<<"\n";
}
}
fi.close();
fo.close();
return 0;
}