Cod sursa(job #411554)

Utilizator NemultumituMatei Ionita Nemultumitu Data 4 martie 2010 23:06:15
Problema Datorii Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.89 kb
#include <cstdio>
int n,m,poz,val,a,b;
int arb[50000];

int query(int nod,int st,int dr)
{
	if (a<=st&&dr<=b)
		return arb[nod];
	int r1=0,r2=0,m=(st+dr)/2;
	if (a<=m)
		r1=query(nod*2,st,m);
	if (b>=m+1)
		r2=query(nod*2+1,m+1,dr);
	return r1+r2;
}

void update(int nod,int st,int dr)
{
	if (st==dr)
	{
		arb[nod]+=val;
		return;
	}
	int m=(st+dr)/2;
	if (poz<=m)
		update(nod*2,st,m);
	else
		update(nod*2+1,m+1,dr);
	arb[nod]=arb[nod*2]+arb[nod*2+1];
}

int main()
{
	freopen ("datorii.in","r",stdin);
	freopen ("datorii.out","w",stdout);
	scanf("%d%d",&n,&m);
	int x,y,z;
	for (int i=1;i<=n;++i)
	{
		scanf("%d",&x);
		poz=i;
		val=x;
		update(1,1,n);
	}
	for (int i=1;i<=m;++i)
	{
		scanf("%d%d%d",&x,&y,&z);
		if (x==0)
		{
			poz=y;
			val=-z;
			update(1,1,n);
		}
		else
		{
			a=y;
			b=z;
			printf("%d\n",query(1,1,n));
		}
	}
	return 0;
}