Pagini recente » Cod sursa (job #3130244) | Cod sursa (job #2260544) | Cod sursa (job #537873) | Cod sursa (job #609504) | Cod sursa (job #2865738)
#include <bits/stdc++.h>
using namespace std;
const int MAXN = 1e5 + 1;
int n, m, v[MAXN], aib[MAXN];
void update(int pos, int val) {
for(int i = pos; i <= n; i += i & -i)
aib[i] += val;
}
int query(int pos) {
int ans = 0;
for(int i = pos; i > 0; i -= i & -i)
ans += aib[i];
return ans;
}
int findPosition(int x) {
int st = 1, dr = n, pos = 0;
while(st <= dr) {
int mid = (st + dr) / 2;
if(query(mid) >= x) {
dr = mid - 1;
pos = mid;
}
else
st = mid + 1;
}
return pos;
}
int main() {
ifstream cin("aib.in");
ofstream cout("aib.out");
cin >> n >> m;
for(int i = 1; i <= n; i++) {
cin >> v[i];
update(i, v[i]);
}
while(m--) {
int op, x, y;
cin >> op >> x;
if(op == 0) {
cin >> y;
update(x, y);
}
else if(op == 1) {
cin >> y;
cout << query(y) - query(x - 1) << '\n';
}
else
cout << findPosition(x) << '\n';
}
return 0;
}