Cod sursa(job #3326463)

Utilizator adimiclaus15Miclaus Adrian Stefan adimiclaus15 Data 29 noiembrie 2025 08:47:26
Problema Arbori de intervale Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.67 kb
//#pragma GCC optimize("O3,Ofast, unroll-loops")
#include <bits/stdc++.h>
using namespace std;

const int NMAX = 1e5;
int v[NMAX + 1];
int aint[4 * 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] = max(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;
        //[st, mid] [mid + 1]
        if(pos <= mid) {
            update(2 * node, st, mid, pos, val);
        } else {
            update(2 * node + 1, mid + 1, dr, pos, val);
        }
        aint[node] = max(aint[2 * node], aint[2 * node + 1]);
    }
}

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


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