RMQ问题 用的st表吧,读入数据挺多的,输出数据也挺多的
我还用了 cout<<endl; T了.. 真的是 做题不带脑子的
#include <bits/stdc++.h>
using namespace std;
const int N = 1e6+;
const int Maxn = ; int n, dp[N][Maxn]; // dp[i][j] 表示 [i, i+2^j-1]区间的最小值 int main()
{
freopen("in.txt","r",stdin);
scanf("%d", &n);
for(int i=; i<n; i++) {
scanf("%d", &dp[i][]);
}
for(int j=; j<=; j++) {
for(int i=; i+(<<j)-<n; i++) {
dp[i][j] = min(dp[i][j-], dp[i+(<<(j-))][j-]);
}
}
int m; scanf("%d", &m);
for(int i=; i<m; i++) {
int u,v; scanf("%d %d", &u, &v);
u--, v--;
int len = v - u + ;
int t = log2(len);
// cout << len << " "<<t <<endl;
// cout << <<endl;
printf("%d\n", min(dp[u][t], dp[v-(<<t)+][t]));
}
return ;
}