题目描述
给定一个长度为 N 的数列,和 M 次询问,求出每一次询问的区间内数字的最大值。
输入格式
第一行包含两个整数 N, M,分别表示数列的长度和询问的个数。
第二行包含 N 个整数(记为 ai),依次表示数列的第 i 项。
接下来 M 行,每行包含两个整数 li,ri,表示查询的区间为 [li,ri]。
输出格式
输出包含 M 行,每行一个整数,依次表示每一次询问的结果。
输入输出样例
输入
8 8
9 3 1 7 5 6 0 8
1 6
1 5
2 7
2 6
1 8
4 8
3 7
1 8
输出
9
9
7
7
9
8
7
9
#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e5 + 10;
int n, m, f[maxn][30];
inline int read() // 快读
{
int x = 0, f = 1;
char ch = getchar();
while(!isdigit(ch)){
if(ch == '-')
f = -1;
ch = getchar();
}
while(isdigit(ch)){
x = x * 10 + ch - 48;
ch = getchar();
}
return x * f;
}
int query(int l, int r) // 查询
{
int k = log2(r - l + 1);
return max(f[l][k], f[r-(1<<k)+1][k]);
}
int main()
{
n = read();
m = read();
for(int i = 1; i <= n; i++)
f[i][0] = read();
for(int j = 1; (1 << j) <= n; j++)
for(int i = 1; i + (1 << j) - 1 <= n; i++)
f[i][j] = max(f[i][j-1], f[i+(1<<(j-1))][j-1]);
for(int i = 1; i <= m; i++){
int l, r;
l = read();
r = read();
printf("%d\n", query(l, r));
}
return 0;
}