Cod sursa(job #3038124)

Utilizator LukyenDracea Lucian Lukyen Data 26 martie 2023 21:12:33
Problema Arbori de intervale Scor 10
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.48 kb
#include <bits/stdc++.h>
using namespace std;
ifstream fin("arbint.in");
ofstream fout("arbint.out");

const int v_len = 101;
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, l, mid);
  buildTree(node * 2 + 1, mid + 1, r);

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

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, l, mid, pos, val);
  else
    updateTree(node * 2 + 1, mid + 1, r, pos, val);

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

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, l, mid, ql, qr);
  if (qr >= mid + 1)
    queryTree(node * 2 + 1, mid + 1, r, ql, qr);
}

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

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

  buildTree(1, 1, n);

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

  return 0;
}