56分求助
查看原帖
56分求助
480948
廖哥的粉丝楼主2021/12/4 16:23
#include<bits/stdc++.h>
using namespace std;
const int MAXN=1e6+10;
inline int read()
{
	int x=0,f=1;char ch=getchar();
	while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();}
	while (ch>='0'&&ch<='9'){x=x*10+ch-48;ch=getchar();}
	return x*f;
}
int Log_[MAXN];
int a[MAXN],f[MAXN][21];
int main(){
	int n,m;
	Log_[0]=-1;
	n=read();m=read();
	for(int i=1;i<=n;i++){
		f[i][0]=read();
		Log_[i]=Log_[i>>1]+1;
		}
	for(int j=1;j<=log2(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,len;
			cin>>l>>r;
			len=r-l+1;
			int j=Log_[len];
			cout<<max(f[l][j],f[r-(1<<j)+1][j])<<endl;
		}
	return 0;
	}
2021/12/4 16:23
加载中...