Balanced Lineup

题目链接:https://www.luogu.com.cn/problem/P2880

 1 #include<cstdio>
 2 #include<cmath>
 3 #include<algorithm>
 4 using namespace std;
 5 const int maxn=5e4+10;
 6 int n, q, h[maxn];
 7 int a, b;
 8 int f[maxn][21], g[maxn][21];
 9 int maxh, minh;
10 void st_create(int n)
11 {
12     int k=log2(n);
13     for(int j=1; j<=k; j++)
14     {
15         for(int i=1; i+(1<<j)-1<=n; i++)
16         {
17             f[i][j]=max(f[i][j-1], f[i+(1<<(j-1))][j-1]);
18             g[i][j]=min(g[i][j-1], g[i+(1<<(j-1))][j-1]);
19         }
20     }
21 }
22 int st_max(int l, int r)
23 {
24     int k=log2(r-l+1);
25     return max(f[a][k], f[b-(1<<k)+1][k]);
26 }
27 int st_min(int l, int r)
28 {
29     int k=log2(r-l+1);
30     return min(g[a][k], g[b-(1<<k)+1][k]);
31 }
32 int main()
33 {
34     scanf("%d%d", &n, &q);
35     for(int i=1; i<=n; i++)
36     {
37         scanf("%d", &h[i]);
38         f[i][0]=g[i][0]=h[i];
39     }
40     st_create(n);
41     while(q--)
42     {
43         scanf("%d%d", &a, &b);
44         maxh=st_max(a, b);
45         minh=st_min(a, b);
46         printf("%d\n", maxh-minh);
47     }
48 
49     return 0;
50 }

 

posted @ 2022-04-15 15:22  TFLSNOI  阅读(21)  评论(0编辑  收藏  举报