Pagini recente » Cod sursa (job #2902281) | Cod sursa (job #1320599) | Cod sursa (job #597805) | Cod sursa (job #2813394) | Cod sursa (job #2221935)
#import<fstream>
int N,o,t,x,y,B['썐'];
int U(int p){for(;N/p;p+=p&-p)B[p]+=x;}
int Q(int p){int s=0;for(;p;p&=~-p)s+=B[p];return s;}
int main(){
std::ifstream f("aib.in");
std::ofstream g("aib.out");
for(f>>N>>o;N/++y;U(y))f>>x;
for(;o--;)
{
f>>t>>y;
int i=0,s=1,z=-1;
for(x=y;N/s;s*=2);
for(;s;s/=2)
if(i + s <= N && x >= B[i + s])
(x -= B[i += s]) || (z = i, s = 0);
t<2&&f>>x;
t?g<<(t&1?Q(x)-Q(y-1):z)<<'\n',0:U(y);
}
}