nyoj 119士兵杀敌(三)(线段树区间最值查询,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 - 来源
source=%E7%BB%8F%E5%85%B8%E6%94%B9%E7%BC%96" style="text-decoration:none; color:rgb(55,119,188)">经典改编
- 上传者
- 张云聪
看到这种题就想到线段树 唉 还是知道的算法太少了
第一次线段树还超时了(粗心 忘记写return 了)
还能够用RMQ算法(比线段树快多了。。) 。百度的。
。。
。
线段树 1836ms 险过。
。。
#include <stdio.h>
#include <algorithm>
using namespace std;
struct node
{
int left,right;
int max_num,min_num;
}tree[100000*4];
void build(int left,int right,int root)
{
tree[root].left=left;
tree[root].right=right;
if(left==right)
{
scanf("%d",&tree[root].max_num);
tree[root].min_num=tree[root].max_num;
return ;
}
else
{
int mid=(left+right)/2;
build(left,mid,root*2);
build(mid+1,right,root*2+1);
tree[root].max_num=max(tree[root*2].max_num,tree[root*2+1].max_num);
tree[root].min_num=min(tree[root*2].min_num,tree[root*2+1].min_num);
}
}
void search(int l,int r,int root,int &c,int &d)
{
if(tree[root].left==l&&tree[root].right==r)
{
c=tree[root].max_num;
d=tree[root].min_num;
return ;
}
int mid=(tree[root].left+tree[root].right)/2;
if(mid>=r)
search(l,r,root*2,c,d);
else if(mid<l)
search(l,r,root*2+1,c,d);
else
{
int c1,d1;
search(l,mid,root*2,c,d);
search(mid+1,r,root*2+1,c1,d1);
c=max(c,c1);
d=min(d,d1);
}
}
int main()
{
int n,k;
scanf("%d %d",&n,&k);
build(1,n,1);
for(int i=0;i<k;i++)
{
int a,b;
int c,d;
scanf("%d %d",&a,&b);
search(a,b,1,c,d);
printf("%d\n",c-d);
}
}
RMQ算法 976ms 节省了近一倍的事件。
假设不懂RMQ (Range Minimum/Maximum Query)算法
点击打开链接我转载的小牛一篇文章
#include <stdio.h>
#include <algorithm>
#include <math.h>
using namespace std;
int min_num[100005][20];
int max_num[100005][20];
int n,k;
void RMQ()
{
for(int i=1;i<20;i++)
{
for(int j=1;j<=n;j++)
{
if(j+(1<<i)-1<=n)
{
max_num[j][i]=max(max_num[j][i-1],max_num[j+(1<<(i-1))][i-1]);
min_num[j][i]=min(min_num[j][i-1],min_num[j+(1<<(i-1))][i-1]);
}
}
} }
int main()
{
scanf("%d %d",&n,&k);
for(int i=1;i<=n;i++)
{
int x;
scanf("%d",&x);
min_num[i][0]=max_num[i][0]=x;
}
RMQ();
for(int i=0;i<k;i++)
{
int a,b;
scanf("%d %d",&a,&b);
int pos=(int)(log(b-a+1.0)/log(2.0));
int max1=max(max_num[a][pos],max_num[b-(1<<pos)+1][pos]);
int min1=min(min_num[a][pos],min_num[b-(1<<pos)+1][pos]);
printf("%d\n",max1-min1);
}
return 0;
}
nyoj 119士兵杀敌(三)(线段树区间最值查询,RMQ算法)的更多相关文章
- NYOJ 116 士兵杀敌 (线段树,区间和)
题目链接:NYOJ 116 士兵杀敌 士兵杀敌(二) 时间限制:1000 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 ...
- 【bzoj4695】最假女选手 线段树区间最值操作
题目描述 给定一个长度为 N 序列,编号从 1 到 N .要求支持下面几种操作:1.给一个区间[L,R] 加上一个数x 2.把一个区间[L,R] 里小于x 的数变成x 3.把一个区间[L,R] 里大于 ...
- 【hdu5306】Gorgeous Sequence 线段树区间最值操作
题目描述 给你一个序列,支持三种操作: $0\ x\ y\ t$ :将 $[x,y]$ 内大于 $t$ 的数变为 $t$ :$1\ x\ y$ :求 $[x,y]$ 内所有数的最大值:$2\ x\ y ...
- 【bzoj4355】Play with sequence 线段树区间最值操作
题目描述 维护一个长度为N的序列a,现在有三种操作: 1)给出参数U,V,C,将a[U],a[U+1],...,a[V-1],a[V]都赋值为C. 2)给出参数U,V,C,对于区间[U,V]里的每个数 ...
- HUD.2795 Billboard ( 线段树 区间最值 单点更新 单点查询 建树技巧)
HUD.2795 Billboard ( 线段树 区间最值 单点更新 单点查询 建树技巧) 题意分析 题目大意:一个h*w的公告牌,要在其上贴公告. 输入的是1*wi的w值,这些是公告的尺寸. 贴公告 ...
- HDU.1556 Color the ball (线段树 区间更新 单点查询)
HDU.1556 Color the ball (线段树 区间更新 单点查询) 题意分析 注意一下pushdown 和 pushup 模板类的题还真不能自己套啊,手写一遍才行 代码总览 #includ ...
- 【POJ 2777】 Count Color(线段树区间更新与查询)
[POJ 2777] Count Color(线段树区间更新与查询) Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4094 ...
- cf834D(dp+线段树区间最值,区间更新)
题目链接: http://codeforces.com/contest/834/problem/D 题意: 每个数字代表一种颜色, 一个区间的美丽度为其中颜色的种数, 给出一个有 n 个元素的数组, ...
随机推荐
- VisualStudio:如何监控 ADO.NET?
背景 很多场景下我们都需要监控 ADO.NET,如:查看某些框架(ORM)生成的 SQL.如何在不能使用 SQL Profile 的情况下监控 SQL 呢?VS 为我们提供了一个工具,本文做一些介绍! ...
- java List转换为字符串并加入分隔符的一些方法总结
方法一: public String listToString(List list, char separator) { StringBuilder sb = new StringBuilder(); ...
- left join 注意事项
相信对于熟悉SQL的人来说,LEFT JOIN非常简单,采用的时候也很多,但是有个问题还是需要注意一下.假如一个主表M有多个从表的话A B C …..的话,并且每个表都有筛选条件,那么把筛选条件放到哪 ...
- 安卓开发(Java)中关于final关键字与线程安全性
前言 学习新知识固然重要,但是时常往回看看,温故知新是很必要的.回顾一下线程安全性和final关键字. 正文 从Java 5开始,final keyword一个特殊用法是在并发库中一个非常重要且经常被 ...
- [Web 前端] inline-block元素设置overflow:hidden属性导致相邻行内元素向下偏移
cp from : https://blog.csdn.net/iefreer/article/details/50421025 在表单修改界面中常会使用一个标签.一个内容加一个修改按钮来组成单行界面 ...
- 7.6 服务远程暴露 - 注册服务到zookeeper
为了安全:服务启动的ip全部使用10.10.10.10 远程服务的暴露总体步骤: 将ref封装为invoker 将invoker转换为exporter 启动netty 注册服务到zookeeper 订 ...
- Windbg命令学习15(bp bm bu bl bc ba断点)
以下以skinhgy为例,windbg附加运行 1. bp 命令是在某个地址下断点, 可以 bp 0x7783FEB 也可以 bp MyApp!SomeFunction . 对于后者,WinDBG 会 ...
- 如何远程运行PowerShell命令?
首先, 被remote运行PowerShell的windows必须已经join了domain. 其次, 该Windows的PowerShell必须开启对remote command的接受, 运行下面的 ...
- Controller向View传递数据
1. 使用ViewData传递数据 我们在Controller中定义如下: ViewData[“Message”] = “Hello word!”; 然后在View中读取Controlle ...
- 用css3和jQuery制作精美的表单
用css3和jQuery制作一个简单的精美表单 html代码如下: <span class="title">Mask Your Input Forms and Make ...