NYoj-119-士兵杀敌(3)-RMQ算法
士兵杀敌(三)
- 描写叙述
-
南将军统率着N个士兵,士兵分别编号为1~N,南将军常常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进行比較,计算出两个人的杀敌数差值。用这样的方法一方面能鼓励杀敌数高的人,还有一方面也算是批评杀敌数低的人,起到了非常好的效果。
所以,南将军常常问军师小工第i号士兵到第j号士兵中。杀敌数最高的人与杀敌数最低的人之间军功差值是多少。
如今,请你写一个程序,帮小工回答南将军每次的询问吧。
注意。南将军可能询问非常多次。
- 输入
- 仅仅有一组測试数据
第一行是两个整数N,Q。当中N表示士兵的总数。Q表示南将军询问的次数。(1<N<=100000,1<Q<=1000000)
随后的一行有N个整数Vi(0<=Vi<100000000),分别表示每一个人的杀敌数。再之后的Q行,每行有两个正正数m,n。表示南将军询问的是第m号士兵到第n号士兵。
- 输出
- 对于每次询问。输出第m号士兵到第n号士兵之间全部士兵杀敌数的最大值与最小值的差。
- 例子输入
-
5 2
1 2 6 9 3
1 2
2 4 - 例子输出
-
1
7 -
#include<cstdio>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#include<queue>
#include<stack>
//#define lowbit(i) i&(-i) //lowbit能够直接define。不须要定义函数
using namespace std; //那么F(i,0)的值是确定的,就为i这个位置所指的元素值,
//这时我们能够把区间[i,i+2^j-1]平均分为两个区间,由于j>=1的时候该区间的长度始终为偶数。
//能够分为区间[i,i+2^(j-1)-1]和区间[i+2^(j-1)-1,i+2^j-1]。即取两个长度为2^(j-1)的块代替和更新长度为2^j的块。
//那么最小值就是这两个区间的最小值的最小值,动态规划为:F[i,j]=min(F[i,j-1],F[i+2^(j-1),j-1]).
//F[i,j]=max(F[i,j-1],F[i+2^(j-1),j-1]).
//k=ln(j-i+1)/ln2
//同理:最大值就是F[i,j]=max(F[i,j-1],F[i+2^(j-1),j-1]).F[i,j]=min(F[i,j-1],F[i+2^(j-1)+1,j-1]);
//
const int N=100100;
int max_sum[20][N],min_sum[20][N];
void RMQ(int num)
{
for(int i=1;i!=20;i++)
{
for(int j=1;j<=num;j++)
{
if(j+(1<<i)-1<=num) //i<<i==2^i
{
max_sum[i][j]=max(max_sum[i-1][j],max_sum[i-1][j+(1<<i>>1)]);
min_sum[i][j]=min(min_sum[i-1][j],min_sum[i-1][j+(1<<i>>1)]); }
}
}
}
int main()
{
int num,query;
while(~scanf("%d %d",&num,&query))
{
for(int i=1;i<=num;i++)
{
scanf("%d",&max_sum[0][i]);
min_sum[0][i]=max_sum[0][i];
}
RMQ(num);
while(query--)
{
int begin,end;
scanf("%d %d",&begin,&end);
int k=(int)(log(end-begin+1.0)/log(2.0));
int max1=max(max_sum[k][begin],max_sum[k][end-(1<<k)+1]);
int min1=min(min_sum[k][begin],min_sum[k][end-(1<<k)+1]);
printf("%d\n",max1-min1);
}
}
return 0;
}
NYoj-119-士兵杀敌(3)-RMQ算法的更多相关文章
- NYOJ 119 士兵杀敌(三) RMQ ST
NYOJ 119 士兵杀敌(三) RMQ ST 题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=119 思路: ST在线 预处理O(nlog ...
- NYOJ 119 士兵杀敌(三)【ST算法】 分类: Brush Mode 2014-11-13 20:56 101人阅读 评论(0) 收藏
题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=119 解题思路: RMQ算法. 不会的可以去看看我总结的RMQ算法. http://blo ...
- nyoj 119士兵杀敌(三)(线段树区间最值查询,RMQ算法)
题目119 题目信息 执行结果 本题排行 讨论区 士兵杀敌(三) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描写叙述 南将军统率着N个士兵,士兵分别编号为1~N,南将军常 ...
- NYOJ 119 士兵杀敌(三)(RMQ算法)
採用的的是小牛的写法,蒟蒻第一次写.. RMQ (Range Minimum/Maximum Query)问题是指:对于长度为n的数列A,回答若干询问RMQ(A,i,j)(i,j<=n).返回数 ...
- nyoj 119 士兵杀敌(三)(RMQ)
士兵杀敌(三) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进 ...
- nyoj 119 士兵杀敌(三)【线段树区间最大值最小值差】
士兵杀敌(三) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进 ...
- NYOJ 119 士兵杀敌(三) (线段树)
题目链接 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进行比较,计算出两个人的杀敌数差值,用这种方法一方面能鼓舞杀敌数高的人,另一方面也算 ...
- nyoj 119: 士兵杀敌(三) 【RMQ模板】
题目链接 贴个板子.. #include<bits/stdc++.h> using namespace std; int n,q; ],d1[][],d2[][]; void RMQ_in ...
- nyoj 119 士兵杀敌(三) 【线段树】【单点更新】
题意:. .. 策略如题. 思路:我们先如果仅仅求某一区间的最大值.我们仅仅须要利用线段树的模板.仅仅须要初始化和询问的时候小小的改动一下.改成祖先结点储存的不再是子节点的和而是两个子节点之间的最大值 ...
- NYOJ 116 士兵杀敌 (线段树,区间和)
题目链接:NYOJ 116 士兵杀敌 士兵杀敌(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:5 描写叙述 南将军手下有N个士兵,分别编号1到N,这些士兵的杀敌数都是已知的 ...
随机推荐
- 最小生成树 Prim(普里姆)算法和Kruskal(克鲁斯特尔)算法
Prim算法 1.概览 普里姆算法(Prim算法),图论中的一种算法,可在加权连通图里搜索最小生成树.意即由此算法搜索到的边子集所构成的树中,不但包括了连通图里的所有顶点(英语:Vertex (gra ...
- STL 优先队列详解
优先队列是一个保证队列里元素单调的队列,我们可以利用它来维护一个线性结构的单调性. 一般的优先队列: 当然需要加头文件 #include <queue> priority_queue &l ...
- 华为S5300系列交换机V100R005SPH020升级补丁
S23_33_53-V100R005SPH020.pat 附件: 链接:https://pan.baidu.com/s/1-qgNEtRsZbNnC4eK4DTctA 密码:wpn3
- Accessing an element's parent with ElementTree(转)
Today I ran across a situation where I needed to programmatically remove specific elements from a KM ...
- BZOJ 2002: [Hnoi2010]Bounce 弹飞绵羊 (动态树LCT)
2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 2843 Solved: 1519[Submi ...
- Asp.net处理程序(第六篇)
四.Web服务处理程序 对于Web服务来说,标准的方式是使用SOAP协议,在SOAP中,请求和回应的数据通过XML格式进行描述.在Asp.net 4.0下,对于Web服务来说,还可以选择支持Ajax访 ...
- blkblock工具1
http://www.ibm.com/developerworks/cn/linux/l-cn-perf1/ http://blog.chinaunix.net/uid-24774106-id-409 ...
- CSerialPort串口类最新修正版(解决关闭死锁问题)
这是一份优秀的类文件,好多的地方值得我们学习,具体在多线程,事件,自定义消息,类的封装方面等等.Remon提供的串口类网址为:http://codeguru.earthweb.com/network/ ...
- MVC客户端使用 Mustache.js把json数据填充到模版中
使用Mustache的好处是:可以把一些反复用到的html部分定义成Mustache模版,以便多次使用.使用Mustache的大致步骤是: →从后台拿到json数据 →获取前台页面预先定义好Musta ...
- Android - 警告Nested weights are bad for performance
Android - 警告Nested weights are bad for performance 本文地址: http://blog.csdn.net/caroline_wendy 原因: Lay ...