Pagini recente » Cod sursa (job #2012820) | Cod sursa (job #562760) | Cod sursa (job #2085469) | Cod sursa (job #2013788) | Cod sursa (job #2071858)
#include <fstream>
#define nmax 100002
using namespace std;
ifstream fin("aib.in");
ofstream fout("aib.out");
int arb[nmax];
int val,n,m,c,x,y;
void update(int poz)
{
while(poz<=n)
{
arb[poz]+=val;
poz+=(poz&-poz);
}
}
int query(int poz)
{
int s=0;
while(poz)
{
s+=arb[poz];
poz-=(poz&-poz);
}
return s;
}
int cautare(int val)
{
int i,pas;
for(pas=1;pas<=n;pas<<=1);
for(i=0;pas;pas>>=1)
{
if(i+pas<=n)
{
if(val>=arb[i+pas])
{
i+=pas;
val-=arb[i];
if(!val) return i;
}
}
}
return -1;
}
int main()
{
fin>>n>>m;
for(int i=1;i<=n;i++)
{
fin>>val;
update(i);
}
for(int i=1;i<=m;i++)
{
fin>>c;
if(c==0)
{
fin>>x>>y;
val=y;
update(x);
}
if(c==1)
{
fin>>x>>y;
fout<<query(y)-query(x-1);
fout<<"\n";
}
if(c==2)
{
fin>>x;
fout<<cautare(x);
fout<<"\n";
}
}
return 0;
}