Cod sursa(job #3353937)

Utilizator adimiclaus15Miclaus Adrian Stefan adimiclaus15 Data 12 mai 2026 18:55:54
Problema Datorii Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.64 kb
// Source: https://usaco.guide/general/io

#include <asm-generic/errno.h>
#include <bits/stdc++.h>
using namespace std;

const int NMAX = 15000;
int aint[4 * NMAX + 1], v[NMAX + 1];
int sol;

void build(int node, int st, int dr) {
    if(st == dr) {
        aint[node] = v[st];
    } else {
        int mid = (st + dr) / 2;
        build(2 * node, st, mid);
        build(2 * node + 1, mid + 1, dr);
        aint[node] = aint[2 * node] + aint[2 * node + 1];
    }
}

void update(int node, int st, int dr, int pos, int val) {
    if(st == dr) {
        aint[node] -= val;
    } else {
        int mid = (st + dr) / 2;
        if(pos <= mid) {
            update(2 * node, st, mid, pos, val);
        } else {
            update(2 * node + 1, mid + 1, dr, pos, val);
        }
        aint[node] = aint[2 * node] + aint[2 * node + 1];
    }
}

void query(int node, int st, int dr, int x, int y) {
    if(x <= st && dr <= y) {
        sol = sol + aint[node];
    } else {
        int mid = (st + dr) / 2;
        //[x, y]
        //[st, mid], [mid + 1, dr]
        if(x <= mid) {
            query(2 * node, st, mid, x, y);
        }
        if(mid + 1 <= y) {
            query(2 * node + 1, mid + 1, dr, x, y);
        }
    }
}

int main() {
    ifstream cin("datorii.in");
    ofstream cout("datorii.out");
	int n, q;
    cin >> n >> q;
    for(int i = 1; i <= n; i++) {
        cin >> v[i];
    }
    build(1, 1, n);
    for(int i = 1; i <= q; i++) {
        int op, x, y;
        cin >> op >> x >> y;
        if(op == 1) {
            sol = 0;
            query(1, 1, n, x, y);
            cout << sol << '\n';
        } else {
            update(1, 1, n, x, y);
        }
    }
}