Pagini recente » Cod sursa (job #1913578) | Cod sursa (job #2547266) | Cod sursa (job #570227) | Cod sursa (job #778127) | Cod sursa (job #1974282)
#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;
}