P3865

恰同学少年,凤华正茂;数风流人物,还看今朝。 / 2024-10-16 / 原文

st表。(还是半懂不懂)

#include <bits/stdc++.h>
using  namespace std;
int n,m,x,y,l,a[100010],f[100010][20];
int main(){
	cin>>n>>m; 
	a[1]=0;
	for(int i=2;i<=n;i++)a[i]=a[i>>1]+1;
	for(int i=1;i<=n;i++)cin>>f[i][0];
	for(int j=1;j<=a[n];j++)for(int i=1;i<=n-(1<<j)+1;i++)f[i][j]=max(f[i][j-1],f[i+(1<<(j-1))][j-1]);
	for(int i=1;i<=m;i++){
		cin>>x>>y; 
		l=a[y-x+1];
		cout<<max(f[x][l],f[y-(1<<l)+1][l])<<endl;
	}
}

本来想交了lg再说的,无奈vjudge日爆