93分#11WA求调
查看原帖
93分#11WA求调
1357471
youtian楼主2025/7/28 11:10
#include <bits/stdc++.h>
using namespace std;
const int N=1e5+5;

int n,m;
int l,r;
int a;
int Log[N];
int f[N][16];

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 main(){
    n=read(),m=read();
    for(int i=1;i<=n;i++){
        a=read();
        f[i][0]=a;
    }
    Log[1]=0;
    for(int i=2;i<=n;i++) Log[i]=Log[i>>1]+1;
    for(int j=1;(1<<j)<=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]);
        }
    }
    while(m--){
        l=read(),r=read();
        int k=Log[r-l+1];
        cout<<max(f[l][k],f[r-(1<<k)+1][k])<<"\n";
    }
    return 0;
}

到底哪里有问题啊

2025/7/28 11:10
加载中...