nyoj119 士兵杀敌(三)
士兵杀敌(三)
- 描述
-
南将军统率着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讲解:解决本题有两种方法,可以用线段树,也可以用RMQ算法,RMQ比较省时间,相对较优秀,
- 其实线段树也是比较常规的方法;
- 代码如下:线段树
-
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxx=;
int a[maxx];
int big,small;
struct node
{
int left,right;
int Max,Min;
}tree[*maxx];
void build(int l,int r,int v)
{
tree[v].left=l;
tree[v].right=r;
if(l==r)
{
tree[v].Max=a[l];
tree[v].Min=a[l];
return ;
}
int mid=(l+r)>>;
build(l,mid,v*);
build(mid+,r,v*+);
tree[v].Max=max(tree[*v].Max,tree[*v+].Max);
tree[v].Min=min(tree[*v].Min,tree[*v+].Min);
}
void query(int a,int b,int v)
{
if(tree[v].left==a && tree[v].right==b)
{
if(tree[v].Max>big) big=tree[v].Max;
if(tree[v].Min<small) small=tree[v].Min;
return ;
}
int mid=(tree[v].left+tree[v].right)>>;
if(b<=mid) query(a,b,*v);
else if(a>mid) query(a,b,*v+);
else
{
query(a,mid,v*);
query(mid+,b,v*+);
}
}
int main()
{
int n,m,q,l,r,i;
scanf("%d%d",&n,&q);
for(i=;i<=n;i++)
scanf("%d",&a[i]);
build(,n,);
for(i=;i<q;i++)
{
scanf("%d%d",&l,&r);
big=-,small=;
query(l,r,);
printf("%d\n",big-small);
}
return ;
}RMQ算法:
#include <iostream>
#include <cmath>
#include <algorithm>
#include <cstdio>
using namespace std;
const int N=; int stmax[N][],stmin[N][],d[]; void init(int n)
{
int i,j;
d[]=;
for(i=;i<=;i++)d[i]=d[i-]<<;
for(i=;i<=n;i++){
scanf("%d",&stmax[i][]);
stmin[i][]=stmax[i][];
}
int len = int(log(n*1.0)/log(2.0));
for(j=;j<=len;j++)
for(i=;i<=n;i++)
if(i+d[j]-<=n)
{
stmax[i][j]=max(stmax[i][j-],stmax[i+d[j-]][j-]);
stmin[i][j]=min(stmin[i][j-],stmin[i+d[j-]][j-]);
}
}
void rmq(int q) //
{
int x,y,len;
while(q--)
{
scanf("%d%d",&x,&y);
len=int(log(y-x+1.0)/log(2.0));
int mmax=max(stmax[x][len],stmax[y-d[len]+][len]);
int mmin=min(stmin[x][len],stmin[y-d[len]+][len]);
printf("%d\n",mmax-mmin);
}
}
int main(){
int n, q;
scanf("%d%d",&n,&q);
init(n);
rmq(q);
return ;
}
nyoj119 士兵杀敌(三)的更多相关文章
- 士兵杀敌 三 --- O( 1 ) 的时间复杂度 .
一看就是 十分简单的 题 , 然后上去开始无脑程序 超时~~~ 感觉时间复杂度 , 已经很低了 , 但是并没有什么卵用 . #include<stdio.h> #in ...
- 士兵杀敌(三)_RMQ(区间最值查询)
士兵杀敌(三) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进 ...
- nyoj 119 士兵杀敌(三)(RMQ)
士兵杀敌(三) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进 ...
- nyoj 119 士兵杀敌(三)【线段树区间最大值最小值差】
士兵杀敌(三) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进 ...
- NYOJ 119 士兵杀敌(三) RMQ ST
NYOJ 119 士兵杀敌(三) RMQ ST 题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=119 思路: ST在线 预处理O(nlog ...
- 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).返回数 ...
- NYIST 119 士兵杀敌(三)
士兵杀敌(三)时间限制:2000 ms | 内存限制:65535 KB难度:5 描述南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进行比较,计算出 ...
- ACM题目————士兵杀敌(三)
[RMQ算法]:用于当数组过于庞大的时候,查询区间的最大(最小)值. 时间复杂度:O(nlogn),主要时间发费在预处理上,查询只要O(1). 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军 ...
随机推荐
- 微信小程序-开发入门(一)
微信小程序已经火了一段时间了,之前一直也在关注,就这半年的发展来看,相对原生APP大部分公司还是不愿意将主营业务放到微信平台上,以免受制于腾讯,不过就小程序的应用场景(用完即走和二维码分发等)还是很值 ...
- HTTP所承载的货物(图像、文本、软件等)要满足的条件
HTTP所承载的货物(图像.文本.软件等)要满足的条件: •可以被正确识别 通过Content-Type 首部说明媒体格式,Content-Language 说明语言,以便浏览器和其他客户端能正确处理 ...
- 为什么需要设置pythonpath环境变量?
# -*- coding: utf-8 -*- #python 27 #xiaodeng #为什么需要设置pythonpath环境变量? #只需设置pythonpath,从而可以从正在用的目录(也就是 ...
- 每天写点shell脚本 (持续更新)
1.显示系统信息脚本 #!/bin/bash #A system information gathering script #Command UNAME="uname -a" pr ...
- Cygwin--unix/linux模拟环境
Cygwin是一个在windows平台上运行的类UNIX模拟环境,是cygnus solutions公司开发的自由软件(该公司开发了很多有用的工具,著名的还有eCos,不过现已被Redhat收购).它 ...
- maven内部运行原理解析(一)
来源于:http://www.jianshu.com/p/0fb5e3fb704d maven至今还是Java编程语言构建的事实标准,大部分项目还在使用maven来进行构建,因此了解maven内部运行 ...
- C++知识整理(进制)
++输出二进制.十进制.八进制和十六进制总结 分类: C++ 2013-01-14 02:26 592人阅读 评论(0) 收藏 举报 在C++中,默认状态下,数据按十进制输入输出.如果要求按八进制或十 ...
- Oracle实例
ORA-12505 Listener refused the connection with following error:ORA-12505,TNS:listener 确定这是连接数据库的SID错 ...
- UE 技巧
http://cache.baiducontent.com/c?m=9d78d513d98416b8599d830e7c01a7170e2585744ddcc4523f8a9c12d522195646 ...
- C# NameValueCollection
一个简单的例子 NameValueCollection markStatus = new NameValueCollection(); string[] ...