Pagini recente » Cod sursa (job #2576127) | Cod sursa (job #3136903) | Cod sursa (job #450655) | Cod sursa (job #3177106) | Cod sursa (job #2812665)
#include <fstream>
using namespace std;
ifstream fin("aib.in");
ofstream fout("aib.out");
#define lsb(X) ((X) & -(X))
int n;
const int NMAX = 100000;
int arb[NMAX+5];
void update(int poz, int val)
{
while(poz<=n)
{
arb[poz]+=val;
poz+=lsb(poz);
}
}
int query(int poz)
{
int s=0;
while(poz>0)
{
s+=arb[poz];
poz-=lsb(poz);
}
return s;
}
int cauta(int maxim)
{
int i, s = 0, poz, nr;
for(i = 1; i <= n ; i=i<<1)
{
if(arb[i]>maxim)
{
poz=i>>1;
s = arb[poz];
nr = poz;
while(s!=maxim)
{
nr+=lsb(poz);
poz = lsb(poz);
s+= arb[poz];
}
return nr;
}
}
}
int main()
{
int i, x, m, pb,y;
fin>>n;
fin>>m;
for(i=1;i<=n;i++)
{
fin>>x;
update(i,x);
}
for(i=1;i<=m;i++)
{
fin>>pb;
if(pb==0)
{
fin>>x>>y;
update(x,y);
}
else
if(pb==1)
{
fin>>x>>y;
fout<<query(y)-query(x-1)<<"\n";
}
else
if(pb==2)
{
fin>>x;
fout<<cauta(x)<<"\n";
}
}
return 0;
}