士兵杀敌(三)

时间限制:2000 ms  |  内存限制:65535 KB
难度:5
 
描述

南将军统率着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 士兵杀敌(三)的更多相关文章

  1. 士兵杀敌 三 --- O( 1 ) 的时间复杂度 .

    一看就是 十分简单的  题  ,   然后上去开始无脑程序 超时~~~      感觉时间复杂度 , 已经很低了  ,  但是并没有什么卵用 . #include<stdio.h> #in ...

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

    士兵杀敌(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5   描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进 ...

  3. nyoj 119 士兵杀敌(三)(RMQ)

    士兵杀敌(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5   描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进 ...

  4. nyoj 119 士兵杀敌(三)【线段树区间最大值最小值差】

    士兵杀敌(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5   描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进 ...

  5. NYOJ 119 士兵杀敌(三) RMQ ST

    NYOJ 119 士兵杀敌(三) RMQ ST 题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=119 思路: ST在线 预处理O(nlog ...

  6. nyoj 119士兵杀敌(三)(线段树区间最值查询,RMQ算法)

    题目119 题目信息 执行结果 本题排行 讨论区 士兵杀敌(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5 描写叙述 南将军统率着N个士兵,士兵分别编号为1~N,南将军常 ...

  7. NYOJ 119 士兵杀敌(三)(RMQ算法)

    採用的的是小牛的写法,蒟蒻第一次写.. RMQ (Range Minimum/Maximum Query)问题是指:对于长度为n的数列A,回答若干询问RMQ(A,i,j)(i,j<=n).返回数 ...

  8. NYIST 119 士兵杀敌(三)

    士兵杀敌(三)时间限制:2000 ms | 内存限制:65535 KB难度:5 描述南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进行比较,计算出 ...

  9. ACM题目————士兵杀敌(三)

    [RMQ算法]:用于当数组过于庞大的时候,查询区间的最大(最小)值. 时间复杂度:O(nlogn),主要时间发费在预处理上,查询只要O(1). 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军 ...

随机推荐

  1. java之八大排序

    的关系:  1.直接插入排序 (1)基本思想:在要排序的一组数中,假设前面(n-1)[n>=2] 个数已经是排 好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数 也是排好顺序的.如此反 ...

  2. 启动mysql出现1067错误

    0. 打开mysql\bin\my.ini,查找[mysqld],在[mysqld]下面添加一行文字,skip-grant-tables 即组成 [mysqld] skip-grant-tables[ ...

  3. h5 微场景

    兔展: http://www.rabbitpre.com/ 易企秀: http://www.eqxiu.com/site/show 云来: http://www.liveapp.cn/

  4. zookeeper工作原理解析

    zookeeper一般用于distributed locking,并不适合用于distributed storage,由于zookeeper的每一个node.也叫做znode的存储容量限制是1M. z ...

  5. windows彻底删除Oralce

    以下是彻底删除Oralce的步骤:1. 开始->设置->控制面板->管理工具->服务停止所有Oracle服务. 2. 开始->程序->Oracle - OraHom ...

  6. gdb 读取elf

    在make file中找到ld,然后将其换成 gdb, 如本例中LINKER = /usr/cygnus/xscale-020523/H-sparc-sun-solaris2.5/bin/xscale ...

  7. js 取值&赋值-form表单

      form表单元素介绍 CreateTime--2016年9月22日10:25:54 Author:Marydon <form> 表单元素. 表单中的元素: <input>表 ...

  8. idea 设置黑色背景

      idea 设置黑色背景 CreateTime--2018年4月26日10:32:38 Author:Marydon 设置-->Appearance-->Theme调为:Darcula- ...

  9. glusterFS的部署流程

    转自:http://www.cnblogs.com/terrycy/p/5915263.html GlusterFS简单配置   1.准备工作 准备三台机器(物理机或者虚拟机均可)用于安装和测试Glu ...

  10. 使用nginx生成缩略图

    nginx中可以使用 --with-http_image_filter_module 这个模块,今天发现在github上发现国人开发的一款模块 模块同时支持 Nginx 和 tengine 本ngin ...