Pagini recente » Cod sursa (job #3278829) | Produse | Cod sursa (job #2462717) | Cod sursa (job #3241393) | Cod sursa (job #2951823)
#include <fstream>
#define lsb(i) (i&(-i))
using namespace std;
ifstream cin("aib.in");
ofstream cout("aib.out");
const int N = 100009;
int n,m,x,cer,a,b;
unsigned long long aib[N];
void Update(int poz,int val)
{
for(int i = poz; i<=n ; i += lsb(i))
aib[i]+=val;
}
long long Sum(int poz)
{
long long sum = 0;
for(int i=poz; i>0 ; i -= lsb(i))
sum += aib[i];
return sum;
}
int Query(int val)
{
int i,step=1;
for(;step<n;step<<=1);
for( i=0 ; step ; step>>=1)
if(i+step<=n && Sum(i+step) <= val)
i += step;
if(Sum(i) == val)return i;
else return -1;
}
int main()
{
cin>>n>>m;
for(int i=1;i<=n;++i)
cin>>x,Update(i,x);
for(int i=1;i<=m;++i)
{
cin>>cer;
if(cer==0)
{
cin>>a>>b;
Update(a,b);
}
else if(cer==1)
{
cin>>a>>b;
cout<<Sum(b) - Sum(a-1)<<'\n';
}
else if(cer==2)
{
cin>>a;
cout<<Query(a)<<'\n';
}
}
return 0;
}