比赛 测试 评测结果 AAAAAAAAAAAAAAAAAA
题目名称 均衡队形 最终得分 100
用户昵称 sakura 运行时间 0.422 s
代码语言 C++ 内存使用 7.94 MiB
提交时间 2017-04-11 20:37:17
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
using namespace std;
int map[50005][20],mapx[50005][20];
int n;
void work()
{
    int i,j;
    for(j=1;1<<j<=n;j++)
    for(i=1;i+(1<<j)-1<=n;i++)//i+(1<<j)-1<=n是为了保证区间左端点不超出总数n
    {
    	map[i][j]=min(map[i][j-1],map[i+(1<<j-1)][j-1]);
    	mapx[i][j]=max(mapx[i][j-1],mapx[i+(1<<j-1)][j-1]);
	}
    //实质是动态规划
}
int question(int z,int y)
{
    int x=int (log(y-z+1)/log(2));//注意y-z要加一才为区间长度
    return max(mapx[z][x],mapx[y-(1<<x)+1][x])-min(map[z][x],map[y-(1<<x)+1][x]);//分别以左右两个端点为基础,向区间内跳1<<x的最
//大值; 
}
int main()
{
	freopen("lineup.in","r",stdin);
	freopen("lineup.out","w",stdout);
    int i,a,b,k;
    scanf("%d",&n);
	scanf("%d",&k);
    
    for(i=1;i<=n;i++)
    {
    	scanf("%d",&map[i][0]);//数据输入加初始化,即从i开始向右走2的0次方的区间中的最大值,(注//意i到i的长度为一)。
        mapx[i][0]=map[i][0];
	}
    
    work();//预处理
    
    for(i=1;i<=k;i++)
        {
            scanf("%d%d",&a,&b);
            printf("%d\n",question(a,b));//输出结果
        }
    return 0;
}