#include <bits/stdc++.h>
using namespace std;
ifstream in("datorii.in");
ofstream out("datorii.out");
int ar[400010],n,m;
void up(int st,int dr,int poz,int poza,int val)
{
if(st>poz||dr<poz)
return;
if(st==dr)
{
ar[poza]-=val;
return;
}
int mij=(dr+st)/2;
up(st,mij,poz,poza*2,val);
up(mij+1,dr,poz,poza*2+1,val);
ar[poza]=ar[poza*2]+ar[poza*2+1];
}
int fnd(int st,int dr,int poza,int a,int b)
{
if(st>b||dr<a)
return 0;
if(st>=a&&dr<=b)
return ar[poza];
int mij=(dr+st)/2;
int fnd1,fnd2;
fnd1=fnd(st,mij,poza*2,a,b);
fnd2=fnd(mij+1,dr,poza*2+1,a,b);
return fnd1+fnd2;
}
int main()
{
in>>n>>m;
for(int i=1;i<=n;i++)
{
int val;
in>>val;
up(1,n,i,1,-val);
}
for(int i=1;i<=m;i++)
{
int v,a,b;
in>>v>>a>>b;
if(v==0)
up(1,n,a,1,b);
if(v==1)
out<<fnd(1,n,1,a,b)<<'\n';
}
return 0;
}