不能理解
查看原帖
不能理解
480934
_LiMLE_楼主2021/10/2 15:49
#include<bits/stdc++.h>

using namespace std;

int f[100001][100];
int a[100001];
int n;

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;
}

inline void prework()
{
	for(int i=1;i<=n;i++) f[i][0]=a[i];
   //m=(int)log(n);
	int m=(int)log(n)/log(2)+1;
	for(int i=1;i<=m;i++)
	{
		for(int j=1;j<=n-(1<<i)+1;j++)
		{
			f[j][i]=max(f[j][i-1],f[j+(1<<i-1)][i-1]);
		}	
	} 
}

inline int get_que(int l,int r)
{
	int k=log(r-l+1)/log(2);
   //return max(f[l][k],f[l+(1<<k)][k]);
	return max(f[l][k],f[r-(1<<k)+1][k]);
}

int main()
{
	int m;
	n=read();m=read();
	for(int i=1;i<=n;i++) cin>>a[i];
	prework();
	for(int i=1;i<=m;i++)
	{
		int x,y;
		x=read();y=read();
		cout<<get_que(x,y)<<endl;
	}
	return 0;
}

注释中的那两处为什么是错的

实在是有点想不通

2021/10/2 15:49
加载中...