Cod sursa(job #3152419)

Utilizator LukyenDracea Lucian Lukyen Data 25 septembrie 2023 03:06:18
Problema Arbori de intervale Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.67 kb
#include <bits/stdc++.h>
using namespace std;
ifstream fin("arbint.in");
ofstream fout("arbint.out");

const int v_len = 100001;
int vec[v_len], tree[v_len * 4 + 5];

void buildTree(int node, int l, int r)
{
    if (l == r)
    {
        tree[node] = vec[l];
        return;
    }

    int mid = (l + r) / 2;

    buildTree(node * 2 + 1, l, mid);
    buildTree(node * 2 + 2, mid + 1, r);

    tree[node] = max(tree[node * 2 + 1], tree[node * 2 + 2]);
}

void updateTree(int node, int l, int r, int pos, int val)
{
    if (l == r)
    {
        tree[node] = vec[l] = val;
        return;
    }

    int mid = (l + r) / 2;
    if (pos <= mid)
        updateTree(node * 2 + 1, l, mid, pos, val);
    else
        updateTree(node * 2 + 2, mid + 1, r, pos, val);

    tree[node] = max(tree[node * 2 + 1], tree[node * 2 + 2]);
}

int maxx = INT_MIN;
void queryTree(int node, int l, int r, int ql, int qr)
{
    if (ql <= l && r <= qr)
    {
        maxx = max(maxx, tree[node]);
        return;
    }

    int mid = (l + r) / 2;
    if (ql <= mid)
        queryTree(node * 2 + 1, l, mid, ql, qr);
    if (qr >= mid + 1)
        queryTree(node * 2 + 2, mid + 1, r, ql, qr);
}

int main()
{
    int n, m;
    fin >> n >> m;

    for (int i = 0; i < n; i++)
        fin >> vec[i];

    buildTree(0, 0, n - 1);

    for (int i = 0; i < m; i++)
    {
        int op, x, y;
        fin >> op >> x >> y;
        if (op == 0)
        {
            maxx = INT_MIN;
            queryTree(0, 0, n - 1, x - 1, y - 1);
            fout << maxx << "\n";
        }
        else
            updateTree(0, 0, n - 1, x - 1, y - 1);
    }

    return 0;
}