标签:
士兵杀敌(三)
南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进行比较,计算出两个人的杀敌数差值,用这种方法一方面能鼓舞杀敌数高的人,另一方面也算是批评杀敌数低的人,起到了很好的效果。
所以,南将军经常问军师小工第i号士兵到第j号士兵中,杀敌数最高的人与杀敌数最低的人之间军功差值是多少。
现在,请你写一个程序,帮小工回答南将军每次的询问吧。
注意,南将军可能询问很多次。
5 2 1 2 6 9 3 1 2 2 4
1 7
思路:看懂了但理解的还不透彻。
代码:
#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; }
标签:
原文地址:http://www.cnblogs.com/TWS-YIFEI/p/5804048.html