勉强算是正经题解
2026-02-05 10:26:25
发布于:广东
3阅读
0回复
0点赞
不正经题解这一块
#include<bits/stdc++.h>
using namespace std;
const int N = 5e5 + 10;
int a[N];
int f[N][23];
int n,m;
void solve(){
cin >> n >> m;
for(int i = 1;i <= n;i++){
cin >> a[i];
f[i][0] = a[i];
}
for(int j = 1;j < 23;j++){
for(int i = 1;i +(1 << j) - 1 <= n;i++){
f[i][j] = min(f[i][j - 1],f[i + (1 << (j -1))][j - 1]);
}
}
for(int i = 1;i <= m;i++){
int l,r;
cin >> l >> r;
int len = log2(r - l + 1);
cout << min(f[l][len],f[r - (1 << len) + 1][len]) << " ";
}
}
signed main(){
solve();
return 0;
}
这里空空如也







有帮助,赞一个