WA on #2 #9
#include <bits/stdc++.h>
using namespace std;
const int maxn = 200005;
int n, m;
int w[maxn * 4], a[maxn];
bool InRange(int L, int R, int l, int r)
{
return (L >= l) && (R <= r);
}
bool OutofRange(int L, int R, int l, int r)
{
return (L > r) || (R < l);
}
void pushup(int u)
{
w[u] = max(w[u * 2], w[u * 2 + 1]);
}
void build(int u, int L, int R)
{
if (L == R)
{
w[u] = a[L];
return;
}
int M = (L + R) / 2;
build(u * 2, L, M);
build(u * 2 + 1, M + 1, R);
pushup(u);
}
void insert(int u, int L, int R, int l, int x)
{
if (L == R)
{
w[u] = max(w[u], x);
return;
}
else if ((L<=l)&&(R>=l))
{
int M = (L + R) / 2;
insert(u * 2, L, M, l, x);
insert(u * 2 + 1, M + 1, R, l, x);
pushup(u);
}
else
{
return;
}
}
int query(int u, int L, int R, int l, int r)
{
if (InRange(L, R, l, r))
{
return w[u];
}
else if (!OutofRange(L, R, l, r))
{
int M = (L + R) / 2;
return max(query(u * 2, L, M, l, r), query(u * 2 + 1, M + 1, R, l, r));
}
else
{
return 0;
}
}
int main()
{
cin >> n >> m;
for (int i = 1; i <= n; i++)
{
cin >> a[i];
}
build(1, 1, n);
char op;
int x, y;
for (int i = 1; i <= m; i++)
{
cin >> op >> x >> y;
if (op == 'Q')
{
cout << query(1, 1, n, x, y) << endl;
}
else
{
insert(1, 1, n, x, y);
}
}
return 0;
}