士兵杀敌(三)_RMQ(区间最值查询)

士兵杀敌(三)

时间限制: 2000 ms  |  内存限制:65535 KB
难度: 5
 
<dl class="problem&#45;display"> <dt> 描述 </dt> <dd>

南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进行比较,计算出两个人的杀敌数差值,用这种方法一方面能鼓舞杀敌数高的人,另一方面也算是批评杀敌数低的人,起到了很好的效果。

所以,南将军经常问军师小工第i号士兵到第j号士兵中,杀敌数最高的人与杀敌数最低的人之间军功差值是多少。

现在,请你写一个程序,帮小工回答南将军每次的询问吧。

注意,南将军可能询问很多次。

</dd> </dl>
 
<dl class="others"> <dt> 输入 </dt> <dd> 只有一组测试数据
第一行是两个整数N,Q,其中N表示士兵的总数。Q表示南将军询问的次数。(1<N<=100000,1<Q<=1000000)
随后的一行有N个整数Vi(0<=Vi<100000000),分别表示每个人的杀敌数。
再之后的Q行,每行有两个正正数m,n,表示南将军询问的是第m号士兵到第n号士兵。 </dd> <dt> 输出 </dt> <dd> 对于每次询问,输出第m号士兵到第n号士兵之间所有士兵杀敌数的最大值与最小值的差。 </dd> <dt> 样例输入 </dt> <dd>
5 2
1 2 6 9 3
1 2
2 4
</dd> <dt> 样例输出 </dt> <dd>
1
7
</dd> <dt> 来源 </dt> <dd> 经典改编 </dd> <dt> 上传者 </dt> <dd> 张云聪 </dd> </dl>

 

 思路:看懂了但理解的还不透彻。

代码:

#include <iostream>
#include <cstdio>
#include <cmath>

using namespace std;

int maxnum[100005][20],minnum[100005][20];

void RMQ(int num){//num位元素个数
    for(int j=1;j<20;j++){
        for(int i=1;i<=num;i++){
            if(i+(1<<j)-1<=num){
                maxnum[i][j]=max(maxnum[i][j-1],maxnum[i+(1<<j-1)][j-1]);
                minnum[i][j]=min(minnum[i][j-1],minnum[i+(1<<j-1)][j-1]);
            }
        }
    }
}

int main()
{
    int n,q;
    int a,b;
    scanf("%d %d",&n,&q);
    for(int i=1;i<=n;i++){
        scanf("%d",&maxnum[i][0]);
        minnum[i][0]=maxnum[i][0];
    }
    RMQ(n);
    for(int i=0;i<q;i++){
        scanf("%d %d",&a,&b);
        int k=(int)(log(b-a+1.0)/log(2.0));
        int maxx=max(maxnum[a][k],maxnum[b-(1<<k)+1][k]);
        int minn=min(minnum[a][k],minnum[b-(1<<k)+1][k]);
        printf("%d\n",maxx-minn);
    }
    return 0;
}

 

全部评论

相关推荐

勤奋努力的椰子这就开摆:美团骑手在美团工作没毛病
投递美团等公司10个岗位
点赞 评论 收藏
分享
头像
11-27 14:28
长沙理工大学
刷算法真的是提升代码能力最快的方法吗?&nbsp;刷算法真的是提升代码能力最快的方法吗?
牛牛不会牛泪:看你想提升什么,代码能力太宽泛了,是想提升算法能力还是工程能力? 工程能力做项目找实习,算法也分数据结构算法题和深度学习之类算法
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务