【再见RMQ】NYOJ-119-士兵杀敌(三),区间内大小差值
2024-09-18 03:29:41
【题目链接:NYOJ-119】
思路:转自 点我 ,讲的挺好。
#include <cstdio>
#include <math.h>
#define max(a,b) ((a>b)?a:b)
#define min(a,b) (a<b?a:b)
const int maxn=;
int h[maxn];
int mx[maxn][],mn[maxn][];
int n,q;
void rmq_init(){
int i,j,t;
for(j=;j<=n;j++) mx[j][]=mn[j][]=h[j];
int m=floor(log((double)n)/log(2.0));
for(i=;i<=m;i++){
for(j=;j<=n;j++){
t = j+(<<(i-));
if(t<=n) mx[j][i]=max(mx[j][i-],mx[t][i-]);
else mx[j][i]=mx[j][i-];
}
}
for(i=;i<=m;i++){
for(j=;j<=n;j++){
t = j+(<<(i-));
if(t<=n) mn[j][i]=min(mn[j][i-],mn[t][i-]);
else mn[j][i]=mn[j][i-];
}
}
}
int rmq(int l,int r){
int m=floor(log((double)(r-l+))/log(2.0));
int a=max(mx[l][m],mx[r-(<<m)+][m]);
int b=min(mn[l][m],mn[r-(<<m)+][m]);
return a-b;
}
int main(){
int i,l,r;
int T,C,L,R;
scanf("%d%d",&n,&q);
for(i = ;i <= n;i++)
scanf("%d",&h[i]);
rmq_init();
while(q--){
scanf("%d%d",&L,&R);
printf("%d\n",rmq(L,R));
}
return ;
}
最新文章
- Linux文件(区域)锁函数 -- open()、fcntl()
- iOS学习24之UIControl及其子类
- for循环使用详解(c语言版)
- 锋利的jQuery-4--$(document).ready()和window.onload方法的区别
- Unix时间戳(Unix timestamp)转换工具
- SQL server 表之间的关系生成图
- 《Java程序设计》第七周学习总结
- 亲测 logminer挖掘
- linux umask使用详解
- Spring的lazy-init详解
- dropdownlist 二级联动
- 基于visual Studio2013解决C语言竞赛题之1094纵横图
- 搭建 Linux 下 GitLab 服务器(转)
- 【noip模拟】Fantasia
- static class 静态类(Java)
- python-第一类对象,闭包,迭代器
- Log4J &; elk 事故总结
- PAT甲题题解-1107. Social Clusters (30)-PAT甲级真题(并查集)
- Centos7下安装zabbix 3.0.19
- KNOCKOUTJS DOCUMENTATION-绑定(BINDINGS)-自定义绑定
热门文章
- Codeforces Round #362 (Div. 2)->;A. Pineapple Incident
- Linux下tcp协议socket的recv函数返回时机分析(粘包)
- 【Entity Framework】 Entity Framework资料汇总
- LA 4384
- JsRender系列demo(2)多模板-template
- django --fields.E304 错误解决方案
- Oracle 9 - 分析undo和snapshot too old错误
- 关于in与exists的效率讨论
- spring @bean注解
- 本人arcgis api for javascript中常见错误总结